黃偉榮的學習筆記

軟體的世界變化萬千,小小的我只能在這洪流奮發向上以求立足。
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

Linq小技巧:日期處理

Posted on 2010-09-14 00:34  黃偉榮  阅读(1226)  评论(0编辑  收藏  举报

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

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

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

 

其實還有更簡單的方式

 

from p in Products
where p.ModifiedDate.Date == DateTime.Today
select p
-- 轉譯的Sql
SELECT *
FROM [Product]
WHERE CONVERT(DATE, [ModifiedDate]) = '2010-09-13 00:00:00.000'

是不是簡單許多呢,當然也可以跟某一天比較,如:

from p in Products
where p.ModifiedDate.Date == new DateTime(2010,1,1)
select p

Tip:

DateTime.Date,是去掉時間只取日期,而DATE,是Sql Server 2008 的只有日期的資料型態。

 

2.找出某年月的資料

from p in Products
where p.ModifiedDate.Year == DateTime.Today.Year && p.ModifiedDate.Month == DateTime.Today.Month
select p
-- 轉譯的Sql
SELECT *
FROM [Product]
WHERE (DATEPART(Year, [ModifiedDate]) = 2010) AND (DATEPART(Month, [ModifiedDate]) = 9)

 

3.加半年就過期的資料

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

 

Note:

用AddHours,AddMinutes,AddSeconds,轉譯的T-Sql,非常的不易閱讀,不過還好平常沒事不用管轉譯結果,長怎麼樣。

如AddHours(6),會轉譯成

DATEADD(ms, (CONVERT(BigInt,6 * 3600000)) % 86400000, DATEADD(day, (CONVERT(BigInt,6 * 3600000)) / 86400000, [ModifiedDate]))

 

我個人覺得用Linq在很多情況下,比T-Sql直覺好用多了,用了二年的Linq,我想我的T-Sql一定退化了很多。

 

參考資料

  1. System.DateTime 方法 (LINQ to SQL)