信息产业培训网

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

http://www.miiceic.org.cn   2008-7-28 9:14:50   中程在线   浏览数:
关键字:讲解 采购价 疑难问题

  碰到一个问题:

 

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

来源:CCID
相关连接
最新评论
*以下网友发言不代表中程在线网站的观点和看法
    我要评论

    请您注意
    1、遵守中华人民共和国的各项有关法律规定
    2、承担一切因您的行为而导致的法律责任
    3、本网留言管理人员有权删除其管辖留言内容
    4、您在本网的留言本网有权在网站内转载和引用
    5、参与本留言即表明您已经阅读并接受上述条款
    我爱研发网中电华信阿里西西JAVA爱好者北京英才网全球大学查询网
    中国人的网站导航中国电脑论坛信息产业部新浪科技搜狐IT信息产业部电子教育与考试中心
    IT世界网软件项目交易网中国软件交易网国信培训网亚远景科技....[更多]
    关于我们 | 网站地图 | 周边住宿 | 行车路线 | 联系我们 | 网站律师 | 意见反馈 | 虚位以待 | 友情链接
    中程在线(北京)科技有限公司 版权所有
    总 部:北京市海淀区青东商务楼A座西四层
    企业培训部:010-52636110 52636106 就业培训部:010-68716925 68716926
    邮 件:training@miiceic.org.cn
    京ICP备06053134号
    Copyright © 2005-2008 Miiceic.org.cn All Rights Reserved