1. ホーム
  2. sql

[解決済み】1つの列のSELECT DISTINCT

2022-03-30 10:35:26

質問

SQL Serverを使用して、私は...

ID  SKU     PRODUCT
=======================
1   FOO-23  Orange
2   BAR-23  Orange
3   FOO-24  Apple
4   FOO-25  Orange

欲しい

1   FOO-23  Orange
3   FOO-24  Apple

このクエリではたどり着けません。どうすれば、1つの列に対してSELECT DISTINCTできるのでしょうか?

SELECT 
[ID],[SKU],[PRODUCT]
FROM [TestData] 
WHERE ([PRODUCT] = 
(SELECT DISTINCT [PRODUCT] FROM [TestData] WHERE ([SKU] LIKE 'FOO-%')) 
ORDER BY [ID]

解決方法は?

SQL Server 2005 以降であれば、ROW_NUMBER() を使った CTE を使用することができます。

SELECT  *
FROM    (SELECT ID, SKU, Product,
                ROW_NUMBER() OVER (PARTITION BY PRODUCT ORDER BY ID) AS RowNumber
         FROM   MyTable
         WHERE  SKU LIKE 'FOO%') AS a
WHERE   a.RowNumber = 1