Агрегатная функция по уникальному идентификатору (GUID) - PullRequest
46 голосов
/ 20 мая 2011

Допустим, у меня есть следующая таблица:

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

В основном я хочу сделать следующий SQL:

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

Это не обязательно должно быть МИН. Я просто хочу вернуть один GUID для каждой категории. Мне все равно, какой. К сожалению, SQL Server не допускает MIN или MAX для идентификаторов GUID.

Конечно, я мог бы преобразовать guid в varchar или создать какой-нибудь вложенный TOP 1 SQL, но это выглядит как уродливый обходной путь. Есть ли какое-то элегантное решение, которое я пропустил?

Ответы [ 5 ]

48 голосов
/ 28 октября 2011

Просто разыграйте его как 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
32 голосов
/ 20 мая 2011

Если вы используете 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
17 голосов
/ 26 августа 2013

Агрегатные функции могут использоваться в столбцах Uniqueidentifier, если версия SQL Server> = 2012

выражение

- это константа, имя столбца или функция и любая комбинация арифметики,побитовые и строковые операторы.MIN может использоваться со столбцами числовых, char, varchar, uniqueidentifier или datetime, но не с битовыми столбцами.Агрегатные функции и подзапросы недопустимы.

4 голосов
/ 20 мая 2011
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   
0 голосов
/ 16 ноября 2014

ВЫБЕРИТЕ верхнюю 1 категорию, гид ИЗ myTable Категория GROUP BY, гид

...