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

代码如下:

/****** 创建表  ******/    
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[Table]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)    
drop table [dbo].[Table]    
GO    
Create TABLE [dbo].[Table] (    
[ID] [int] IDENTITY (1, 1) NOT NULL ,    
[Y] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,    
[X] [smalldatetime] NOT NULL   
) ON [PRIMARY]    
GO    
--插入数据    
Insert INTO [Table](Y, X) values('CCC', '2007-02-02 02:02:02')    
Insert INTO [Table](Y, X) values('AAA', '2007-02-02 02:02:02')    
Insert INTO [Table](Y, X) values('AAA', '2007-03-03 03:03:03')    
Insert INTO [Table](Y, X) values('BBB', '2007-01-01 01:01:01')    
Insert INTO [Table](Y, X) values('BBB', '2007-02-02 02:02:02')    
Insert INTO [Table](Y, X) values('BBB', '2007-03-03 03:03:03')    
Insert INTO [Table](Y, X) values('CCC', '2007-01-01 01:01:01')    
Insert INTO [Table](Y, X) values('AAA', '2007-01-01 01:01:01')    
Insert INTO [Table](Y, X) values('CCC', '2007-03-03 03:03:03')    
Insert INTO [Table](Y, X) values('DDD', '2007-01-01 01:01:01')    
Insert INTO [Table](Y, X) values('DDD', '2007-02-02 02:02:02')    
Insert INTO [Table](Y, X) values('DDD', '2007-03-03 03:03:03')    
Insert INTO [Table](Y, X) values('EEE', '2007-01-01 01:01:01')    
Insert INTO [Table](Y, X) values('EEE', '2007-02-02 02:02:02')    
Insert INTO [Table](Y, X) values('EEE', '2007-03-03 03:03:03')    
GO

/****** 创建表  ******/ 
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[Table]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) 
drop table [dbo].[Table] 
GO 
Create TABLE [dbo].[Table] ( 
[ID] [int] IDENTITY (1, 1) NOT NULL , 
[Y] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL , 
[X] [smalldatetime] NOT NULL 
) ON [PRIMARY] 
GO 
--插入数据 
Insert INTO [Table](Y, X) values('CCC', '2007-02-02 02:02:02') 
Insert INTO [Table](Y, X) values('AAA', '2007-02-02 02:02:02') 
Insert INTO [Table](Y, X) values('AAA', '2007-03-03 03:03:03') 
Insert INTO [Table](Y, X) values('BBB', '2007-01-01 01:01:01') 
Insert INTO [Table](Y, X) values('BBB', '2007-02-02 02:02:02') 
Insert INTO [Table](Y, X) values('BBB', '2007-03-03 03:03:03') 
Insert INTO [Table](Y, X) values('CCC', '2007-01-01 01:01:01') 
Insert INTO [Table](Y, X) values('AAA', '2007-01-01 01:01:01') 
Insert INTO [Table](Y, X) values('CCC', '2007-03-03 03:03:03') 
Insert INTO [Table](Y, X) values('DDD', '2007-01-01 01:01:01') 
Insert INTO [Table](Y, X) values('DDD', '2007-02-02 02:02:02') 
Insert INTO [Table](Y, X) values('DDD', '2007-03-03 03:03:03') 
Insert INTO [Table](Y, X) values('EEE', '2007-01-01 01:01:01') 
Insert INTO [Table](Y, X) values('EEE', '2007-02-02 02:02:02') 
Insert INTO [Table](Y, X) values('EEE', '2007-03-03 03:03:03')

GO解决“每个Y的最新X”经典SQL问题:以下几种方法真是八仙过海


代码如下:

Select ID, Y, X   
FROM [Table] T1   
Where (NOT EXISTS   
(Select 1   
FROM [Table] T2   
Where (T2.Y = T1 .Y) AND (T2.X > T1 .X or  
T2.X = T1 .X AND T2.ID > T1 .ID)))   
/*****************************************************************************/   
Select *   
FROM [Table]   
Where ID IN  
(Select MAX(T1.ID)   
FROM [Table] T1 JOIN  
(Select y, MAX(x) x   
FROM [Table]   
GROUP BY y) T2 ON T1.Y = T2.Y AND T1.x = T2.x   
GROUP BY T1.y)   
/*****************************************************************************/   
Select T .ID, T .Y, T .X   
FROM [Table] T INNER JOIN  
(Select MAX(T1.ID) AS ID   
FROM [Table] T1 JOIN  
(Select y, MAX(x) x   
FROM [Table]   
GROUP BY y) T2 ON T1.Y = T2.Y AND T1.x = T2.x   
GROUP BY T1.y) T2 ON T .ID = T2.ID   
/*****************************************************************************/   
Select *   
FROM [Table] T1   
Where ID IN  
(Select TOP 1 ID   
FROM [Table]   
Where Y = T1.Y   
orDER BY X DESC)   
/*****************************************************************************/   
Select *   
FROM [Table] T1   
Where (ID =   
(Select TOP 1 ID   
FROM [Table]   
Where Y = T1.Y   
orDER BY X DESC, ID DESC))   
/*****************************************************************************/

/*****************************************************************************/
Select ID, Y, X
FROM [Table] T1
Where (NOT EXISTS
(Select 1
FROM [Table] T2
Where (T2.Y = T1 .Y) AND (T2.X > T1 .X or
T2.X = T1 .X AND T2.ID > T1 .ID)))
/*****************************************************************************/
Select *
FROM [Table]
Where ID IN
(Select MAX(T1.ID)
FROM [Table] T1 JOIN
(Select y, MAX(x) x
FROM [Table]
GROUP BY y) T2 ON T1.Y = T2.Y AND T1.x = T2.x
GROUP BY T1.y)
/*****************************************************************************/
Select T .ID, T .Y, T .X
FROM [Table] T INNER JOIN
(Select MAX(T1.ID) AS ID
FROM [Table] T1 JOIN
(Select y, MAX(x) x
FROM [Table]
GROUP BY y) T2 ON T1.Y = T2.Y AND T1.x = T2.x
GROUP BY T1.y) T2 ON T .ID = T2.ID
/*****************************************************************************/
Select *
FROM [Table] T1
Where ID IN
(Select TOP 1 ID
FROM [Table]
Where Y = T1.Y
orDER BY X DESC)
/*****************************************************************************/
Select *
FROM [Table] T1
Where (ID =
(Select TOP 1 ID
FROM [Table]
Where Y = T1.Y
orDER BY X DESC, ID DESC))

/*****************************************************************************
/效率嘛,在不同的字段建立索引速度都不尽相同,使用者见仁见智了. 
第一种方法速度在各方面都不错,而且在Y列在建立索引,可以大大优化查询速度。

(0)

相关推荐

  • 一条语句简单解决“每个Y的最新X”的经典sql语句

    复制代码 代码如下: /****** 创建表  ******/     if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[Table]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)     drop table [dbo].[Table]     GO     Create TABLE [dbo].[Table] (     [ID] [int] IDENTIT

  • Mssql,Access的sql经典SQL语句大全

    下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL-数据定义语言(CREATE,ALTER,DROP,DECLARE) DML-数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL-数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK) 首先,简要介绍基础语句: 1.说明:创建 数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份

  • 经典SQL语句大全第1/2页

    下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL-数据定义语言(CREATE,ALTER,DROP,DECLARE) DML-数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL-数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK) 一.基础 1.说明:创建数据库 复制代码 代码如下: CREATE DATABASE database-name 2.说明:删除数据库 复制代码 代码如下: drop database d

  • PHP执行批量mysql语句的解决方法

    当有多条mysql语句连起来需要执行,比如 $sqls= "insert table a values(1,2); insert table a values(2,3);" 需要执行的话php中可以使用的方法有三个: mysql_query pdo mysqli 三种方法当sqls语句没有问题的时候都是可以的. 但是 当sql语句是错误的时候会出现问题第一条sql错误:三个方法都返回false 第一条sql正确,第二条sql错误:mysql_query.pdo. mysqli:quer

  • 写出高性能SQL语句的35条方法分析

    (1)整合简单,无关联的数据库访问: 如果你有几个简单的数据库查询语句,你可以把它们整合到一个查询中(即使它们之间没有关系) (2)删除重复记录: 最高效的删除重复记录方法 ( 因为使用了ROWID)例子: DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID) FROM EMP X WHERE X.EMP_NO = E.EMP_NO); (3)用TRUNCATE替代DELETE: 当删除表中的记录时,在通常情况下, 回滚段(rollback

  • Oracle之SQL语句性能优化(34条优化方法)

    好多同学对sql的优化好像是知道的甚少,最近总结了以下34条仅供参考. (1)选择最有效率的表名顺序(只在基于规则的优化器中有效): ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处理,在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表.如果有3个以上的表连接查询, 那就需要选择交叉表(intersection table)作为基础表, 交叉表是指那个被其他表所引用的表. (2) WH

  • 查询mysql中执行效率低的sql语句的方法

    一些小技巧1. 如何查出效率低的语句?在MySQL下,在启动参数中设置 --log-slow-queries=[文件名],就可以在指定的日志文件中记录执行时间超过long_query_time(缺省为10秒)的SQL语句.你也可以在启动配置文件中修改long query的时间,如: 复制代码 代码如下: # Set long query time to 8 seconds    long_query_time=8 2. 如何查询某表的索引?可使用SHOW INDEX语句,如: 复制代码 代码如下

  • sql语句优化之SQL Server(详细整理)

    MS SQL Server查询优化方法 查询速度慢的原因很多,常见如下几种 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计算列导致查询不优化. 4.内存不足 5.网络速度慢 6.查询出的数据量过大(可以采用多次查询,其他的方法降低数据量) 7.锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷) 8.sp_lock,sp_who,活动的用户查看,原因是读写竞争资源. 9.返回了不必要的行和列 10.查询语句不好,

  • SQL语句优化提高数据库性能

    性能不理想的系统中除了一部分是因为应用程序的负载确实超过了服务器的实际处理能力外,更多的是因为系统存在大量的SQL语句需要优化.为了获得稳定的执行性能,SQL语句越简单越好.对复杂的SQL语句,要设法对之进行简化. 常见的简化规则如下: 1)不要有超过5个以上的表连接(JOIN) 2)考虑使用临时表或表变量存放中间结果 3)少用子查询 4)视图嵌套不要过深,一般视图嵌套不要超过2个为宜 一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的的编写等体会不出S

  • 分组后分组合计以及总计SQL语句(稍微整理了一下)

    今天看到了这个文章感觉内容挺多的,就是比较乱,实在不好整理,我们小编就简单整理了一下,希望大家能凑合看吧 分组后分组合计以及总计SQL语句   1)想一次性得到分组合计以及总计,sql: SELECT 分组字段 FROM 表 GROUP BY 分组字段 compute sum(COUNT(*)) 2)分组合计1: SELECT COUNT(*) FROM (SELECT 分组字段 FROM 表 GROUP BY 分组字段 )别名 3)分组合计2: SELECT COUNT(*) FROM (SE

随机推荐