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

一沙一世界 一花一天堂 掌中握無……

网络编程技术、多媒体技术、PC应用技术

| 我爱研发网 | 中电华信 | 阿里西西 | JAVA爱好者 | 北京英才网 | 全球大学查询网 |
| 中国人的网站导航 | 中国电脑论坛 | 信息产业部 | 新浪科技 | 搜狐IT | 信息产业部电子教育与考试中心 |
| IT世界网 | 软件项目交易网 | 中国软件交易网 | 国信培训网 | 亚远景科技 | ....[更多] |