Linq小技巧:日期處理

DateTime的屬性如:Date、Year,方法如:AddDays、AddYears,都會轉成Sql,知道轉譯的方法,對操作Linq To Sql或Entity Framework會更方便上手,下面介紹幾個情況給大家參考,詳細內容請看MSDN。

 

1.Today或某天的處理

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

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

 

其實還有更簡單的方式

 

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

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

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

Tip:

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

 

2.找出某年月的資料

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

 

3.加半年就過期的資料

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

 

Note:

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

如AddHours(6),會轉譯成

1 DATEADD(ms, (CONVERT(BigInt,6 * 3600000)) % 86400000, DATEADD(day, (CONVERT(BigInt,6 * 3600000)) / 86400000, [ModifiedDate]))
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值