Uniqueidentifier(GUID)上的聚合函数

时间:2011-05-20 08:33:16

标签: sql sql-server guid aggregate uniqueidentifier

假设我有下表:

category | guid
---------+-----------------------
   A     | 5BC2...
   A     | 6A1C...
   B     | 92A2...

基本上,我想做以下SQL:

SELECT category, MIN(guid)
  FROM myTable
 GROUP BY category

它不一定是MIN。我只想返回每个类别的一个 GUID。我不在乎哪一个。不幸的是,SQL Server不允许在GUID上使用MIN或MAX。

当然,我可以将guid转换为varchar,或者创建一些嵌套的TOP 1 SQL,但这似乎是一个丑陋的解决方法。我错过了一些优雅的解决方案吗?

5 个答案:

答案 0 :(得分:47)

只需将其投放为BINARY(16)

SELECT category, MIN(CAST(guid AS BINARY(16)))
FROM myTable
GROUP BY category

如有必要,您可以稍后将其丢弃。

WITH CategoryValue
AS
(    
    SELECT category, MIN(CAST(guid AS BINARY(16)))
    FROM myTable
    GROUP BY category
)
SELECT category, CAST(guid AS UNIQUEIDENTIFIER)
FROM CategoryValue

答案 1 :(得分:32)

假设您使用的是SQL Server 2005或更高版本:

;with Numbered as (
     select category,guid,ROW_NUMBER() OVER (PARTITION BY category ORDER BY guid) rn
     from myTable
)
select * from Numbered where rn=1

答案 2 :(得分:17)

如果SQL Server版本> = 2012

,则可以在Uniqueidentifier列上使用聚合函数
  

表达

     

是常量,列名称或函数,以及它的任意组合   算术,按位和字符串运算符。 MIN可以搭配使用   numeric,char,varchar,uniqueidentifier或datetime列,但不是   有位列。聚合函数和子查询不是   允许的。

答案 3 :(得分:4)

declare @T table(category char(1), guid uniqueidentifier) 

insert into @T 
select 'a', newid() union all
select 'a', newid() union all
select 'b', newid()

select
  S.category,
  S.guid
from
(  
  select
    T.category,
    T.guid,
    row_number() over(partition by T.category order by (select 1)) as rn
  from @T as T
) as S
where S.rn = 1

如果您使用的是SQL Server 2000,则可以使用

select 
  T1.category,
  (select top 1 T2.guid 
   from @T as T2
   where T1.category = T2.category) as guid
from @T as T1
group by T1.category   

答案 4 :(得分:-4)

选择前1个类别,guid   来自myTable  GROUP BY类别,guid