讲解一个检索最近日期的采购价的疑难问题
作者:林梦 出处:赛迪网 更新时间:2008-08-06 责任编辑:seward
 
 

      碰到一个问题:

如下一个表,暂定为test,是记录各个商品在不同日期的采购价。

商品编码 品名 采购价 日期

AFBJ001 小方桌 28.0 2005-06-11 00:00:00.000

AFBJ001 小方桌 28.0 2006-05-26 00:00:00.000

AFBJ001 小方桌 24.0 2005-08-31 00:00:00.000

AFBJ001 小方桌 28.0 2005-12-29 00:00:00.000

AFBJ001 小方桌 28.0 2006-01-26 00:00:00.000

AFBJ001 小方桌 28.0 2006-04-29 00:00:00.000

AFBJ001 小方桌 30.0 2006-03-31 00:00:00.000

AFBJ001 小方桌 28.0 2006-03-17 00:00:00.000

AFBJ001 小方桌 32.0 2006-03-24 00:00:00.000

AFBJ002 方桌 60.0 2005-06-11 00:00:00.000

AFBJ002 方桌 25.0 2006-05-26 00:00:00.000

AFBJ002 方桌 55.0 2005-08-31 00:00:00.000

 

要求一个sql语句,查询结果如下,检索出最近一次采购价格!

 

商品编码 品名 采购价 日期

AFBJ001 小方桌 28.0 2006-05-26 00:00:00.000

AFBJ002 方桌 25.0 2006-05-26 00:00:00.000

 

一般的写法是:

select t1.* from test t1,(select 商品编码,max(日期) as 日期 from test group by 商品编码) t2

where t1.编码=t2.编码 and t1.日期= t2.日期

 

后来看到了一个更高效的写法:

select * from test a WHERE 1>(SELECT COUNT( * ) FROM test b WHERE a.日期

若要是检索最近n次的采购价,也可以使用上述语句:

 

select * from test a WHERE n>(SELECT COUNT( * ) FROM test b WHERE a.日期

 
     
 
 
继续>>SQL Server
[第1页][第2页][下一页]
 
内容导航  
第1页讲解一个检索最近日期.. 第2页SQL Server
上一篇 : 一些文档中没有介绍的SQ.. 下一篇讲解SQL Server危险扩展..
 
  您要为所发表的言论的后果负责,请各位遵纪守法并注意文明用语
标题:  

[ 关于本站 ] [ 广告服务 ] [ 商务合作 ] [ 联系我们 ] [ 合作伙伴 ] [ 法律顾问 ] [ 网站地图 ]
千橡公司 京ICP证041489号 Copyright (c) 1997-2007 All Right Reserved.