基于值重置行 ID
row ID reset based on Value
我需要生成一个基于 ID 的商店并随时重置交易类型 = 200。下面是我的数据示例。
StoreID TransactionID
A 200
A 300
A 45
A 1
A 200
A 23
A 2000
A 200
A 1
现在,我需要填充它。
每次显示 200 时重置的行号。
一笔交易可以有多个 ID,也可以有不同数量的交易。但是 200 是 BeginingOftransaction,所以我需要能够获取 ID 并在 200 上重置。
Rn StoreID TransactionID
1 A 200
2 A 300
3 A 45
4 A 1
1 A 200
2 A 23
3 A 2000
1 A 200
2 A 1
试试这个代码。如果交易 ID 等于 200
,这将重置为 1
SELECT
(CASE
WHEN TransactionID = 200 THEN @rn := 1
ELSE @rn := @rn + 1
END) AS RN, StoreID, TransactionID
FROM TableName, (SELECT @rn := 0);
这适用于 SQL 服务器:
希望这正是您想要的。试试这个:
DECLARE @Tab TABLE(StoreID VARCHAR(1),id int)
INSERT INTO @Tab VALUES('A',200),('A',89),('A',89),('A',98),('A',200),('A',1),('A',3),('A',200)
SELECT SUM(1) OVER(PARTITION BY D.RES ORDER BY RN)RN,StoreID,ID
from(
SELECT id,StoreID, RN
,SUM(CASE WHEN id=200 THEN 1 ELSE 0 END) OVER(ORDER BY (SELECT RN))Res
FROM (
SELECT id,StoreID,ROW_NUMBER() OVER(ORDER BY(SELECT NULL))RN
FROM @Tab)D
)D
结果是:
RN StoreID ID
1 A 200
2 A 89
3 A 89
4 A 98
1 A 200
2 A 1
3 A 3
1 A 200
我需要生成一个基于 ID 的商店并随时重置交易类型 = 200。下面是我的数据示例。
StoreID TransactionID
A 200
A 300
A 45
A 1
A 200
A 23
A 2000
A 200
A 1
现在,我需要填充它。 每次显示 200 时重置的行号。 一笔交易可以有多个 ID,也可以有不同数量的交易。但是 200 是 BeginingOftransaction,所以我需要能够获取 ID 并在 200 上重置。
Rn StoreID TransactionID
1 A 200
2 A 300
3 A 45
4 A 1
1 A 200
2 A 23
3 A 2000
1 A 200
2 A 1
试试这个代码。如果交易 ID 等于 200
,这将重置为 1 SELECT
(CASE
WHEN TransactionID = 200 THEN @rn := 1
ELSE @rn := @rn + 1
END) AS RN, StoreID, TransactionID
FROM TableName, (SELECT @rn := 0);
这适用于 SQL 服务器:
希望这正是您想要的。试试这个:
DECLARE @Tab TABLE(StoreID VARCHAR(1),id int)
INSERT INTO @Tab VALUES('A',200),('A',89),('A',89),('A',98),('A',200),('A',1),('A',3),('A',200)
SELECT SUM(1) OVER(PARTITION BY D.RES ORDER BY RN)RN,StoreID,ID
from(
SELECT id,StoreID, RN
,SUM(CASE WHEN id=200 THEN 1 ELSE 0 END) OVER(ORDER BY (SELECT RN))Res
FROM (
SELECT id,StoreID,ROW_NUMBER() OVER(ORDER BY(SELECT NULL))RN
FROM @Tab)D
)D
结果是:
RN StoreID ID
1 A 200
2 A 89
3 A 89
4 A 98
1 A 200
2 A 1
3 A 3
1 A 200