C# ling to sql 取多條記錄最大時間的例項程式碼

低调码农哥發表於2019-10-10

文章主要介紹了C# ling to sql 取多條記錄最大時間,文中透過例項程式碼給大家介紹了sql 查詢相同記錄下日期最大的 一條,程式碼簡單易懂,需要的朋友可以參考下

具體程式碼如下所述:

var _setList = (from f in _postgreDbContext.settlements
                           group f by ( new { f.settlement_code })into g
                 select new
                 {
                   deal_time = g.Max(m => m.deal_time),
                   g.Key.settlement_code
                 }).AsNoTracking().ToList();

知識點擴充套件:sql 查詢相同記錄下日期最大的 一條

日期 編號 倉庫 數量

2012-05-31 C001 A店 136.00
2012-05-29 C001 A店 139.00
2012-05-29 C001 B店 5.00
2012-05-30 C001 B店 6.00

我只顯示最大日期的記錄,這個SQL怎麼寫呀?


日期 編號 倉庫 數量

2012-05-31 C001 A店 136.00
2012-05-30 C001 B店 6.00

SQL code

select * from tb t where not exists ( select 1 from tb where 編號 = t.編號 and 倉庫 = t.倉庫 and 日期 > t.日期)

方法2:

create table cangku ( F_RQ datetime, F_BH VARCHAR(20), F_SL FLOAT )
 
INSERT INTO cangku VALUES('2012-05-31','C001',343) INSERT INTO cangku VALUES('2012-05-30','C001',34) INSERT INTO cangku VALUES('2012-05-30','C002',33) INSERT INTO cangku VALUES('2012-05-26','C002',23)
 
SELECT * FROM cangku T,(SELECT F_BH,MAX(F_RQ) rq FROM cangku GROUP BY F_BH) t2 where t.F_BH=t2.F_BH and t.F_RQ>=t2.rq

方法3:更好理解:

select * from table a where a.date in (select max(b.date) from table b where b.id=a.id)

總結

以上所述是小編給大家介紹的C# ling to sql 取多條記錄最大時間,希望對大家有所幫助。

相關文章