Linq小技巧:日期處理
来源:互联网 发布:可视化数据调度平台 编辑:程序博客网 时间:2024/06/07 20:32
DateTime的屬性如:Date、Year,方法如:AddDays、AddYears,都會轉成Sql,知道轉譯的方法,對操作Linq To Sql或Entity Framework會更方便上手,下面介紹幾個情況給大家參考,詳細內容請看MSDN。
1.Today或某天的處理
如果要找出今天修改的資料,你會怎麼下,像下面這樣嗎?
1
from
p
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
p
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
p
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
p
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
p
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]))
- Linq小技巧:日期處理
- Linq的小技巧
- 日期输出小技巧
- 使用LINQ的几个小技巧
- mysql 日期小技巧方案
- 【经验总结】shell 日期小技巧
- 小技巧:js日期比较
- 日期减日期的小技巧
- Linq技巧
- linq to sql生成not in语句的小技巧
- EF(Linq)框架使用过程中的小技巧汇总
- t-sql日期函数小技巧
- 日期时间字符串的改写小技巧
- java获取日期的小技巧
- JS日期比较的一个小技巧
- 小技巧(五)格式化日期为短日期
- LINQ之日期函数
- linq日期转换
- NSUserDefaults存储数据
- 让Extjs加加速
- SQL SERVER中事务日志在修改数据时的角色
- iOS 两个应用之间的切换
- JIG(即时绘图)-直线即时绘图-EntityJig(单实体即时绘图)
- Linq小技巧:日期處理
- HTML,CSS,font-family:中文字体的英文名称 (宋体 微软雅黑)
- Github 基本操作
- hibernate JPA 单表树形结构 注解配置
- Microsoft Robotics Developer Studio 4之VPL4的遇到的问题及解决方案
- 配置管理建设的一点体会
- 使用Ext的Grid,Form,Dialog来实现分页列表,创建,修改,删除功能
- 第二次课后习题作业
- 图的存储结构-邻接表-边集数组-前向星