一条语句简单解决“每个Y的最新X”的SQL经典问…

2008-02-23 07:43:48来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

  “每个Y的最新X”是个经典的SQL问题,工作中经常碰到。当然不是“按Y分组求最新的X值”那么简单,需要最新X的那条记录或主键ID。用一条SQL语句能够简单的解决此问题。

  生成实例表和数据:

--创建表
CREATE TABLE dbo.Tab
(
ID int NOT NULL IDENTITY (1, 1),
Y varchar(20) NOT NULL,
X datetime NOT NULL
)
GO
--插入数据
INSERT INTO Tab(Y, X) values('BBB', '2007-10-23 11:11:11')
INSERT INTO Tab(Y, X) values('BBB', '2007-10-23 11:11:11')
INSERT INTO Tab(Y, X) values('BBB', '2007-10-23 10:10:10')
INSERT INTO Tab(Y, X) values('AAA', '2007-10-23 12:12:12')
INSERT INTO Tab(Y, X) values('AAA', '2007-10-23 10:10:10')
INSERT INTO Tab(Y, X) values('AAA', '2007-10-23 11:11:11')
GO

  解决“每个Y的最新X”经典SQL问题:

--一条SQL语句实现
SELECT ID, Y, X
FROM Tab T
WHERE (NOT EXISTS
(SELECT 1
FROM Tab T2
WHERE (T2.Y = T.Y) AND (T2.X > T.X OR
T2.X = T.X AND T2.ID > T.ID)))

  在Y列在建立索引,能够大大优化查询速度。


标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: MYSQL的master/slave数据同步配置

下一篇: 动态配置并加密App.Config中数据库连接字符串