Linq小技巧:日期处理

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.Date == DateTime.Today
select p

SELECT *
FROM [Product]
WHERE CONVERT(DATE, [ModifiedDate]) = '2010-09-13 00:00:00.000'

是不是简单许多呢,当然也可以跟某一天比较,如:


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

Tip:

DateTime.Date,是去掉时间只取日期,而DATE,是Sql Server 2008 的只有日期的数据型态。

 

2.找出某年月的数据


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'

Note:

用AddHours,AddMinutes,AddSeconds,转译的T-Sql,非常的不易阅读,不过还好平常没事不用管转译结果,长怎么样。

如AddHours(6),会转译成


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

参考数据

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

原文:大专栏  Linq小技巧:日期处理


猜你喜欢

转载自www.cnblogs.com/petewell/p/11465364.html