添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

Linq處理日期的小技巧,你知道嗎?Linq對DateTime的處理如:屬性、方法,是支援轉譯的,原來Linq的DateTime處理可以這樣寫。

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或某天的處理

如果要找出今天修改的資料,你會怎麼下,像下面這樣嗎?


where p.ModifiedDate >= DateTime.Today && p.ModifiedDate < DateTime.Today.AddDays(1)
select p
SELECT * FROM [Product] WHERE ([ModifiedDate] >= '2010-09-13 00:00:00.000' ) AND ([ModifiedDate] < '2010-09-14 00:00:00.000')

其實還有更簡單的方式

where p.ModifiedDate.Year == DateTime.Today.Year && p.ModifiedDate.Month == DateTime.Today.Month select p SELECT * FROM [Product] WHERE (DATEPART(Year, [ModifiedDate]) = 2010) AND (DATEPART(Month, [ModifiedDate]) = 9)

3.加半年就過期的資料

where p.ModifiedDate.AddMonths(6) >= DateTime.Today select p SELECT * FROM [Product] WHERE DATEADD(MONTH, 6, [PeriodDate]) >= '2010-09-14 00:00:00.000'