为了账号安全,请及时绑定邮箱和手机立即绑定

重复记录的取最新一笔

标签:
JavaScript

一位网友在Insus.NET下班时问及一个SQL问题,他有如下一些记录:

S_NUMBER       P_NO     UPDATE_TIME
Y1202022524   E3465   2012-02-05 16:32:16.000
Y1202022524   E0035   2012-01-16 05:38:41.000
Y1202022525   E0036   2012-01-17 05:38:41.000
Y1202022526   E0037   2012-01-18 05:38:41.000
Y1202022527   E0038   2012-01-19 05:38:41.000
Y1202022528   E0039   2012-01-20 05:38:41.000
Y1202022529   E0040   2012-01-21 05:38:41.000

 

要SELECT所有记录,过滤所有重复[S_NUMBER]的记录,只取[UPDATE_TIME]最新的一笔。

下面是Insus.NET帮他解决的方法与过程:

创建一个临时表#Data

CREATE TABLE [#Datas]
(
    S_NUMBER NVARCHAR(30),
    P_NO NVARCHAR(30),
    UPDATE_TIME DATETIME
)

 

把数据插入这个临时表中:

5acf07280001405b00110016.jpgView Code INSERT INTO [#Datas] VALUES 
('Y1202022524', 'E3465', '2012/02/05 16:32:16'),
('Y1202022524', 'E0035', '2012/01/16 05:38:41'),
('Y1202022525', 'E0036', '2012/01/17 05:38:41'),
('Y1202022526', 'E0037', '2012/01/18 05:38:41'),
('Y1202022527', 'E0038', '2012/01/19 05:38:41'),
('Y1202022528', 'E0039', '2012/01/20 05:38:41'),
('Y1202022529', 'E0040', '2012/01/21 05:38:41')

GO

 

下面SELECT是在MS SQL Server 2008 R2查询分析器实现:

5acf07280001405b00110016.jpgView Code WITH it([S_NUMBER],[UPDATE_TIME])
AS
(
    SELECT [S_NUMBER],MAX([UPDATE_TIME]) FROM [dbo].[#Datas] GROUP BY [S_NUMBER]    
)
SELECT DISTINCT d.[S_NUMBER],[P_NO],d.[UPDATE_TIME] 
FROM [dbo].[#Datas] AS d 
INNER JOIN it
 ON (d.[S_NUMBER] = it.[S_NUMBER] and d.[UPDATE_TIME] = it.[UPDATE_TIME]);

 

执行结果:

 

 

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
移动开发工程师
手记
粉丝
18
获赞与收藏
134

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消