我有以下数据
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发布于 2017-10-18 18:07:44
您可以使用STRING_AGG ( Server 2017及以上)获取一个级别的所有级别,然后使用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演示
https://stackoverflow.com/questions/46816440
复制相似问题