Linq處理日期的小技巧,你知道嗎?Linq對DateTime的處理如:屬性、方法,是支援轉譯的,原來Linq的DateTime處理可以這樣寫。
測試工具:LinqPad 4.26
測試環境:
- .Net Framework 4.0
- Sql Server 2008 R2(因為手邊沒有2008以下的環境,沒試過在2008以下會怎麼樣)
DateTime的屬性如:Date、Year,方法如:AddDays、AddYears,都會轉成Sql,知道轉譯的方法,對操作Linq To Sql或Entity Framework會更方便上手,下面介紹幾個情況給大家參考,詳細內容請看MSDN。
1.Today或某天的處理
如果要找出今天修改的資料,你會怎麼下,像下面這樣嗎?
1 2 3 | from p in Products where p.ModifiedDate >= DateTime.Today && p.ModifiedDate < DateTime.Today.AddDays(1) select p |
1 2 3 4 | -- 轉譯的Sql SELECT * FROM [Product] WHERE ([ModifiedDate] >= '2010-09-13 00:00:00.000' ) AND ([ModifiedDate] < '2010-09-14 00:00:00.000' ) |
其實還有更簡單的方式
1 2 3 | from p in Products where p.ModifiedDate. Date == DateTime.Today select p |
1 2 3 4 | -- 轉譯的Sql SELECT * FROM [Product] WHERE CONVERT ( DATE , [ModifiedDate]) = '2010-09-13 00:00:00.000' |
是不是簡單許多呢,當然也可以跟某一天比較,如:
1 2 3 | from p in Products where p.ModifiedDate. Date == new DateTime(2010,1,1) select p |
Tip:
DateTime.Date,是去掉時間只取日期,而DATE,是Sql Server 2008 的只有日期的資料型態。
2.找出某年月的資料
1 2 3 | from p in Products where p.ModifiedDate. Year == DateTime.Today. Year && p.ModifiedDate. Month == DateTime.Today. Month select p |
1 2 3 4 | -- 轉譯的Sql SELECT * FROM [Product] WHERE (DATEPART( Year , [ModifiedDate]) = 2010) AND (DATEPART( Month , [ModifiedDate]) = 9) |
3.加半年就過期的資料
1 2 3 | from p in Products where p.ModifiedDate.AddMonths(6) >= DateTime.Today select p |
1 2 3 4 | -- 轉譯的Sql SELECT * FROM [Product] WHERE DATEADD( MONTH , 6, [PeriodDate]) >= '2010-09-14 00:00:00.000' |
Note:
用AddHours,AddMinutes,AddSeconds,轉譯的T-Sql,非常的不易閱讀,不過還好平常沒事不用管轉譯結果,長怎麼樣。
如AddHours(6),會轉譯成
1DATEADD(ms, (
CONVERT
(
BigInt
,6 * 3600000)) % 86400000, DATEADD(
day
, (
CONVERT
(
BigInt
,6 * 3600000)) / 86400000, [ModifiedDate]))
我個人覺得用Linq在很多情況下,比T-Sql直覺好用多了,用了二年的Linq,我想我的T-Sql一定退化了很多。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?