我有以下数据
CREATE TABLE customers (ID INT, rankVal INT);
GO
INSERT INTO dbo.customers( ID, rankVal )
VALUES ( 1, -- ID - int
1 -- rankVal - int
),
( 1, -- ID - int
2 -- rankVal - int
),
( 2, -- ID - int
1 -- rankVal - int
),
( 2, -- ID - int
2 -- rankVal - int
),
( 3, -- ID - int
1 -- rankVal - int
),
( 3, -- ID - int
3 -- rankVal - int
),
( 4, -- ID - int
1 -- rankVal - int
),
( 4, -- ID - int
3 -- rankVal - int
);
我想将我的客户分成小组。例如,客户1和2具有完全相同的排名,它们必须位于单个组中,客户3和4必须位于不同的组中。预期结果
Grp costumerID
---- -----------
gr1 1
gr1 2
gr2 3
gr2 4
答案 0 :(得分:5)
您可以使用STRING_AGG
(SQL Server 2017及更高版本)将所有排名设置为1,然后使用DENSE_RANK
计算组的编号:
WITH cte AS (
SELECT ID, STRING_AGG(rankVal,',') WITHIN GROUP (ORDER BY rankVal) AS s
FROM customers
GROUP BY ID
)
SELECT CONCAT('grp', DENSE_RANK() OVER(ORDER BY s)) AS GRP, ID AS customerID
FROM cte;
<强> DBFiddle Demo 强>