您的位置:首页 >> 数据库 >> MSSQL Server >> 正文
MSSQL Server RSS
 

讲解一个检索最近日期的采购价的疑难问题

http://www.rdxx.com 08年07月28日 00:00 赛迪网 我要投稿

关键词: 问题 , 日期 , 检索

  碰到一个问题:

  如下一个表,暂定为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.日期  


 
 
标签: 问题 , 日期 , 检索 打印本文
 
 
  热点搜索
 
 
 



Valid XHTML 1.0 Transitional
Copyright ©2005 - 2008 Rdxx.Com,All Rights Reserved
收藏本页
收藏本站