MyException - 我的异常网
当前位置:我的异常网» Sql Server » 请问一个查询

请问一个查询

www.MyException.Cn  网友分享于:2013-04-27  浏览:2次
请教一个查询
请教我想查询时返回的记录中取item对应的edate最大值。
item不能重复。

item                           price                             sdate                     edate

5930 2.6053800000 2011-06-30   00:00:00.000 2011-07-12   16:40:55.873
5930 2.8989900000 2011-09-17   00:00:00.000 2011-09-23   10:54:09.357
5930 2.4201600000 2012-02-26   00:00:00.000 2012-02-20   12:00:40.543
5936 0.1962000000 2010-07-01   00:00:00.000 2010-07-14   00:00:00.000
5936 0.2009400000 2010-08-25   00:00:00.000 2010-09-21   13:45:53.140
5936 0.2071600000 2010-09-26   00:00:00.000 2010-10-26   13:53:33.390
5936 0.2071630000 2010-09-26   00:00:00.000 2010-11-04   14:47:27.357
5936 0.2277860000 2010-10-21   00:00:00.000 2010-12-10   18:15:51.373
12200 1.4949600000 2010-07-01   00:00:00.000 2010-07-14   00:00:00.000
12200 1.4983400000 2010-08-25   00:00:00.000 2010-09-21   13:45:53.140
12200 1.5636100000 2010-09-26   00:00:00.000 2010-10-26   13:53:33.390
12200 1.5636050000 2010-09-26   00:00:00.000 2010-11-04   14:47:27.357

------解决方案--------------------
SQL code
--2005以上版本
select item,price,sdate,edate from(
select *,row_number()over(partition by item order by edate desc)as id from tbl
) a where id=1
--2000版本
select * from tbl a where edate=(select max(edate) from tbl b where a.item=b.item)

------解决方案--------------------
SQL code
if object_id('[TB]') is not null drop table [TB]
go
create table [TB] (item int,price numeric(11,10),sdate datetime,edate datetime)
insert into [TB]
select 5930,2.6053800000,'2011-06-30 00:00:00.000','2011-07-12 16:40:55.873' union all
select 5930,2.8989900000,'2011-09-17 00:00:00.000','2011-09-23 10:54:09.357' union all
select 5930,2.4201600000,'2012-02-26 00:00:00.000','2012-02-20 12:00:40.543' union all
select 5936,0.1962000000,'2010-07-01 00:00:00.000','2010-07-14 00:00:00.000' union all
select 5936,0.2009400000,'2010-08-25 00:00:00.000','2010-09-21 13:45:53.140' union all
select 5936,0.2071600000,'2010-09-26 00:00:00.000','2010-10-26 13:53:33.390' union all
select 5936,0.2071630000,'2010-09-26 00:00:00.000','2010-11-04 14:47:27.357' union all
select 5936,0.2277860000,'2010-10-21 00:00:00.000','2010-12-10 18:15:51.373' union all
select 12200,1.4949600000,'2010-07-01 00:00:00.000','2010-07-14 00:00:00.000' union all
select 12200,1.4983400000,'2010-08-25 00:00:00.000','2010-09-21 13:45:53.140' union all
select 12200,1.5636100000,'2010-09-26 00:00:00.000','2010-10-26 13:53:33.390' union all
select 12200,1.5636050000,'2010-09-26 00:00:00.000','2010-11-04 14:47:27.357'

select * from [TB]



select distinct B.item,b.price,b.sdate,b.edate
from TB A
cross apply(select top 1 item,price,sdate,edate from TB where item = A.item order by edate desc) B


/*
5930    2.4201600000    2012-02-26 00:00:00.000    2012-02-20 12:00:40.543
5936    0.2277860000    2010-10-21 00:00:00.000    2010-12-10 18:15:51.373
12200    1.5636050000    2010-09-26 00:00:00.000    2010-11-04 14:47:27.357*/

------解决方案--------------------
SQL code

select a.* 
from tab a
inner join
(select item,max(edate) maxedate
from tab group by item) b
on a.item=b.item and a.edate=b.maxedate

------解决方案--------------------
SQL code

selct distinct item,max(edate) from 表 gourp by item

------解决方案--------------------

文章评论

程序员和编码员之间的区别
程序员和编码员之间的区别
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
每天工作4小时的程序员
每天工作4小时的程序员
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
鲜为人知的编程真相
鲜为人知的编程真相
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
总结2014中国互联网十大段子
总结2014中国互联网十大段子
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
我的丈夫是个程序员
我的丈夫是个程序员
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
如何成为一名黑客
如何成为一名黑客
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
中美印日四国程序员比较
中美印日四国程序员比较
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
编程语言是女人
编程语言是女人
程序员都该阅读的书
程序员都该阅读的书
程序员必看的十大电影
程序员必看的十大电影
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
代码女神横空出世
代码女神横空出世
程序员应该关注的一些事儿
程序员应该关注的一些事儿
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
漫画:程序员的工作
漫画:程序员的工作
旅行,写作,编程
旅行,写作,编程
老程序员的下场
老程序员的下场
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
我是如何打败拖延症的
我是如何打败拖延症的
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
 程序员的样子
程序员的样子
一个程序员的时间管理
一个程序员的时间管理
10个调试和排错的小建议
10个调试和排错的小建议
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有