碰到一個問題:
如下一個表,暫定為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.日期
新聞熱點
疑難解答