gpt4 book ai didi

sql - TSQL:获取每个案例的最后一个用户......一个记录x用户

转载 作者:行者123 更新时间:2023-12-04 03:11:06 29 4
gpt4 key购买 nike

情景:
想象一个像这样的表:

Auto_INC, UserID_FK, CaseID_FK,    Date
idX userX caseX

当它被填充时,它看起来像这样:

   id1,     user4,     case20,   2010/01/12  
id2, user1, case13, 2010/03/20
id3, user2, case10, 2010/03/22
id4, user1, case21, 2011/01/10
id5, user2, case9, 2011/01/11
id6, user3, case20, 2011/02/01
id7, user1, case9, 2011/03/25

问题:
我如何获得最后一个用户分配的一个案例记录?

因此,如果已分配一个用户,它将自动覆盖该案例中的所有先前用户。

是这样的:

   id7,     user1,      case9,   2011/03/25  
id2, user1, case13, 2010/03/20
id4, user1, case21, 2011/01/10
id6, user3, case20, 2011/02/01
id3, user2, case10, 2010/03/22

在这种情况下,用户 1 已分配给 3 个案例,用户 2 分配给 2 个案例,但一个被用户 1 覆盖,用户 3 有 1 个案例并且它确实覆盖了用户 4 ...所以用户 4 没有得到任何案例 ..因此它不会出现在列表中。

请注意
理想情况下,我们应该得到结果......与原始表中的 CASES 一样多的记录!!!

最佳答案

declare @T table
(
Auto_INC int identity primary key,
UserID_FK int,
CaseID_FK int,
[Date] date
);

insert into @T values
(4, 20, '2010/01/12'),
(1, 13, '2010/03/20'),
(2, 10, '2010/03/22'),
(1, 21, '2010/01/10'),
(2, 9, '2010/01/11'),
(3, 20, '2010/02/01'),
(1, 9, '2010/03/25');

with C as
(
select *,
row_number() over(partition by CaseID_FK
order by [Date] desc) as rn
from @T
)
select Auto_INC, UserID_FK, CaseID_FK, [Date]
from C
where rn = 1;

结果:

Auto_INC    UserID_FK   CaseID_FK   Date
----------- ----------- ----------- ----------
7 1 9 2010-03-25
3 2 10 2010-03-22
2 1 13 2010-03-20
6 3 20 2010-02-01
4 1 21 2010-01-10

关于sql - TSQL:获取每个案例的最后一个用户......一个记录x用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8005853/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com