博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EF架构~在Linq to Entity中使用日期函數
阅读量:6149 次
发布时间:2019-06-21

本文共 1563 字,大约阅读时间需要 5 分钟。

眾所周知,在linq to entity的查询语句中,不允许出现ef不能识别的关键字,如Trim,Substring,TotalDays等.net里的关键字,在EF查询里都是不被支持的,它的原因可能是为了更好的提高查询的性能吧,毕竟,好的性能取决于你的程序标准,有了一个严格的标准,才能设计出好的程序来.

今天主要说一下,EF为日期方法留的一个后门,<后门>这个词大家在中国社会都应该知道了,顾名思义,就是反着原则走,你的原则对我没有用,哈哈!这东西有时候是有用的,因为在大的原则下,很可能一些需求无法实现,这时,就需要后门了!

EF里的后门类:

System.Data.Objects.SqlClient.SqlFunctions

下面我们看一个例子,这个例子涉及到了一个根据时间的查询

public System.Linq.Expressions.Expression
> SatisfiedBy() { Specification
spec = new TrueSpecification
(); if (_status.HasValue) { if (_status.Value == 0) spec &= new DirectSpecification
(o => (o.Status & (int)Status.AuditNotPass) > 0 || (o.Status & (int)Status.Auditing) > 0 || DateTime.Now < o.BeginTime); else if (_status == 1) spec &= new DirectSpecification
(o => (o.Status & (int)Status.AuditPass) > 0 && System.Data.Objects.SqlClient.SqlFunctions.DateDiff("mi", DateTime.Now, o.BeginTime) < o.Minutes); else spec &= new DirectSpecification
(o => (o.Status & (int)Status.AuditPass) > 0 && System.Data.Objects.SqlClient.SqlFunctions.DateDiff("mi", DateTime.Now, o.BeginTime) > o.Minutes); } return spec.SatisfiedBy(); }

下面是关于dataPart参数的说明,来自http://www.w3school.com.cn/sql/func_datediff.asp

datepart 缩写
yy, yyyy
季度 qq, q
mm, m
年中的日 dy, y
dd, d
wk, ww
星期 dw, w
小时 hh
分钟 mi, n
ss, s
毫秒 ms
微妙 mcs
纳秒 ns

本文转自博客园张占岭(仓储大叔)的博客,原文链接:,如需转载请自行联系原博主。

你可能感兴趣的文章
私.01.serialport
查看>>
使用LocalBroadcastManager
查看>>
测试开发面试准备之HTTP协议-一次完整的Http请求过程
查看>>
Linux学习笔记11—VSFTP的搭建
查看>>
Python学习(18)面向对象
查看>>
Django级联删除的选项
查看>>
new option
查看>>
ES6初探,什么是ES6
查看>>
ORACLE用户操作的一些常用操作总结【weber出品】
查看>>
redhat9 linux 网卡无法激活排障
查看>>
实践详细篇-Windows下使用VS2015编译安装Caffe环境(CPU ONLY)
查看>>
go 成长路上的坑(1)
查看>>
设计模式之建造者模式
查看>>
T4 assembly
查看>>
zabbix添加nginx中间件监控
查看>>
使用Spire.Doc组件利用模板导出Word文档
查看>>
PF_RING 总结
查看>>
Palindrome Number
查看>>
正向代理与反向代理
查看>>
EditPlus自动补全、模板配置
查看>>