Access911.net   |   a9BBS   |   OTaA System  
  搜索文章︰  
Access911歡迎您光臨  
   主頁      上傳      简体版       論壇     
設為首頁  |  加入收藏   
  
你現在的位置︰文章索引 -> 文章分類 -> 查詢  
 首頁|  近日更新|  下載  |  文章索引  |  搜索|  朮語|  承接工程|  
 
系統正在加載內容,請耐心等待...
 
 查詢
 窗体
 報表
 
 
 VBA
 函數
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 發布
 OA
 ASP/ASP.NET
 其他語言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用軟件
 參考文檔
 業主作品
 网友大作
 
 
友情鏈接
 access911.net
 
訪問人次
 1701872
 
站長 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 訂閱

顯示附加信息 >>>

如何實現分組按日期排倒序再按ID排倒序每組取一條記錄?

作者︰cg1  摘自︰access911.net  ︰cg1  更新日期︰2010-4-16  瀏覽人次︰

 

問題︰

有個問題︰

         數據表︰
               id              組號              日期              數值
                 1                15          2010-5-1                55
                 2                15          2010-1-1                68
                 3                11          2010-7-1                 1
                 4                19          2010-4-1            332223
                 5                11          2010-8-1               323
                 6                 7          2010-1-1                40
                 7                 9          2010-2-1               378


         查詢結果
               id              組號              日期              數值
                 1                15          2010-5-1                55
                 4                19          2010-4-1            332223
                 5                11          2010-8-1               323
                 6                 7          2010-1-1                40
                 7                 9          2010-2-1               378


要求是根據數據表的內容,按日期排序取每組最後那條記錄的數值,如果日期有重复那么取ID最大的那條。而且注意要先按日期排倒序,再按ID排倒序,每組只取一條。

 


回答︰

SELECT b.*
FROM [temp] AS a 
    right JOIN [temp] AS b ON (a.日期>b.日期 
                                        or (a.日期=b.日期 and  a.ID>b.ID)) 
    AND a.組號 =b.組號
where a.id is null


或者

select a.*     
from [temp] as   a     
where     
    not exists(select 1
                from [temp] as b     
                where     
                    組號=a.組號 
                    and (日期>a.日期 
                        or (日期=a.日期 and ID>a.ID))) 

 


Function CreateExampleTable()
    CurrentProject.Connection.Execute "create table [temp] (id AUTOINCREMENT(1,1) ,[組號] string,[日期] date,[數值] long)  "
    CurrentProject.Connection.Execute "insert into [temp](id,組號,日期,數值) values(1,15,#2010-5-1#,55)    "
    CurrentProject.Connection.Execute "insert into [temp](id,組號,日期,數值) values(2,15,#2010-1-1#,68)    "
    CurrentProject.Connection.Execute "insert into [temp](id,組號,日期,數值) values(3,11,#2010-7-1#,1)    "
    CurrentProject.Connection.Execute "insert into [temp](id,組號,日期,數值) values(4,19,#2010-4-1#,332223)    "
    CurrentProject.Connection.Execute "insert into [temp](id,組號,日期,數值) values(5,11,#2010-8-1#,323)    "
    CurrentProject.Connection.Execute "insert into [temp](id,組號,日期,數值) values(6,7,#2010-1-1#,40) "
    CurrentProject.Connection.Execute "insert into [temp](id,組號,日期,數值) values(7,9,#2010-2-1#,378) "
End Function

Function CreateQuery()
    CurrentProject.Connection.Execute "create view [V_先按日期再按ID排序取每組最後一條數據] as SELECT b.* FROM [temp] AS a    right JOIN [temp] AS b ON (a.日期>b.日期                                         or (a.日期=b.日期 and  a.ID>b.ID))    AND a.組號 =b.組號 where a.id is null"
End Function



附記︰在T-SQL中為沒有ID列的表生成ID字段的方法︰
select newid() as id,* from table
select identity(int,1,1) as ID ,* into temptable from loginuser

本站文章旨在為該問題提供解決思路及關鍵性代碼,并不能完成應該由网友自己完成的所有工作,請网友在仔細看文章并理解思路的基礎上舉一反三、靈活運用。

access911.net 原創文章,作者本人對文章保留一切權利。
如需轉載必須征得作者同意并注明本站鏈接

 

 
相關文章
     沒有手動相關文章
     關于 Partition 函數在分組查詢中的應用
     新手來看︰如何寫分組取前N條的 SQL 語句?
 
評論
     查看或發表更多的評論,請單擊這里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期︰2000年4月2日  |  設計施工︰陳格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陳格 保留所有權利