兴国资源网 Design By www.nnzcdc.com
复制代码 代码如下:
/****** 创建表 ******/
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列在建立索引,可以大大优化查询速度。
/****** 创建表 ******/
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列在建立索引,可以大大优化查询速度。
兴国资源网 Design By www.nnzcdc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
兴国资源网 Design By www.nnzcdc.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年07月04日
2024年07月04日
- 中国音乐地图之听见江苏昆曲经典唱段2020[WAV+分轨]
- 《路易吉鬼屋2HD》GS 7分:适合掌机模式短时间游玩
- 《路易吉鬼屋2HD》M站均分77:出色3DS游戏的升级版
- 不输官方!玩家设计《光环》等主题Switch Pro手柄
- 王识贤.2010-伤心手指【华特】【WAV+CUE】
- 尚雯婕.2009-时代女性Time.Lady【华谊兄弟】【FLAC+CUE】
- 萧亚轩.2006-1087【华纳】【WAV+CUE】
- 徐佳莹《无损音乐合集》2009-2023[FLAC/分轨][2.3GB]
- 群星《那些年的男神,那些年的女神》2CD[WAV+CUE][1.4GB]
- 张学友《2023头版蜚声环球合集》32CD[WAV+CUE][15.7G]
- 绝区零珂蕾妲关键天赋是什么 珂蕾妲天赋效果解析
- 绝区零珂蕾妲音擎武器怎么选 珂蕾妲音擎选择推荐
- 绝区零护盾鸣徽有哪些 绝区零护盾鸣徽效果介绍
- 爱浪音响测试碟-《经典传说》2CD[DTS-WAV]
- 群星《情歌1号-2号(紫银合金)4CD》[WAV+CUE]