Ответ 1
Предполагая, что вы используете 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
Скажем, у меня есть следующая таблица:
category | guid
---------+-----------------------
A | 5BC2...
A | 6A1C...
B | 92A2...
В принципе, я хочу сделать следующий SQL:
SELECT category, MIN(guid)
FROM myTable
GROUP BY category
Это необязательно должно быть MIN. Я просто хочу вернуть один GUID каждой категории. Меня не волнует, какой из них. К сожалению, SQL Server не позволяет использовать MIN или MAX для GUID.
Конечно, я мог бы преобразовать guid в varchar или создать некоторый вложенный TOP 1 SQL, но это похоже на уродливое обходное решение. Есть ли какое-то элегантное решение, которое я пропустил?
Предполагая, что вы используете 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
Просто введите его как 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
Агрегатные функции могут использоваться в столбцах Uniqueidentifier, если версия SQL Server >= 2012
Выражение
Является константой, именем столбца или функцией и любой комбинацией арифметические, поразрядные и строковые. MIN может использоваться с числовые, char, varchar, uniqueidentifier или столбцы datetime, но не с битовыми столбцами. Совокупные функции и подзапросы не являются допускается.
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
SELECT top 1 category, guid FROM myTable GROUP BY категории, guid