EF架构~在Linq to Entity中使用日期函數

回到目录

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

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

EF里的后门类:

System.Data.Objects.SqlClient.SqlFunctions

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

复制代码
   public System.Linq.Expressions.Expression<Func<Classroom_Live, bool>> SatisfiedBy()
    {
            Specification<Classroom_Live> spec = new TrueSpecification<Classroom_Live>();

            if (_status.HasValue)
            {
                if (_status.Value == 0)
                    spec &= new DirectSpecification<Classroom_Live>(o => (o.Status & (int)Status.AuditNotPass) > 0
                        || (o.Status & (int)Status.Auditing) > 0
                        || DateTime.Now < o.BeginTime);
                else if (_status == 1)
                    spec &= new DirectSpecification<Classroom_Live>(o => (o.Status & (int)Status.AuditPass) > 0
                        && System.Data.Objects.SqlClient.SqlFunctions.DateDiff("mi", DateTime.Now, o.BeginTime) < o.Minutes);
                else
                    spec &= new DirectSpecification<Classroom_Live>(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

回到目录

posted @   张占岭  阅读(8627)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
历史上的今天:
2013-07-23 千位分隔符,万位分隔,那个更好!
2012-07-23 代码重构~目录
点击右上角即可分享
微信分享提示