Uniqueidentifier(GUID)上的聚合函数

Hei*_*nzi 47 sql sql-server guid aggregate uniqueidentifier

假设我有下表:

category | guid
---------+-----------------------
   A     | 5BC2...
   A     | 6A1C...
   B     | 92A2...
Run Code Online (Sandbox Code Playgroud)

基本上,我想做以下SQL:

SELECT category, MIN(guid)
  FROM myTable
 GROUP BY category
Run Code Online (Sandbox Code Playgroud)

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

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

小智 48

把它当成一个BINARY(16).

SELECT category, MIN(CAST(guid AS BINARY(16)))
FROM myTable
GROUP BY category
Run Code Online (Sandbox Code Playgroud)

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

WITH CategoryValue
AS
(    
    SELECT category, MIN(CAST(guid AS BINARY(16)))
    FROM myTable
    GROUP BY category
)
SELECT category, CAST(guid AS UNIQUEIDENTIFIER)
FROM CategoryValue
Run Code Online (Sandbox Code Playgroud)

  • 你可以把它转换成一个字符串 - "MIN(CAST(guid AS VARCHAR(36)))` (6认同)

Dam*_*ver 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
Run Code Online (Sandbox Code Playgroud)


doe*_*rig 18

如果SQL Server版本> = 2012,则可以在Uniqueidentifier列上使用聚合函数

表达

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

  • +1 - 链接到[2008 R2]中的"MIN"(http://technet.microsoft.com/en-us/library/ms179916(v = sql.105).aspx)vs [2012](http:// technet.microsoft.com/en-us/library/ms179916(v=sql.110).aspx) (3认同)