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

本文转自博客园张占岭(仓储大叔)的博客,原文链接:EF架构~在Linq to Entity中使用日期函數,如需转载请自行联系原博主。

目录
打赏
0
0
0
0
17
分享
相关文章
开发与运维函数问题之iLogtail原有架构中配置文件组织存在问题如何解决
开发与运维函数问题之iLogtail原有架构中配置文件组织存在问题如何解决
59 1
|
10月前
|
在x86架构汇编语言中函数参数传递的三种约定
在x86架构汇编语言中函数参数传递的三种约定
278 2
编码之道:从函数到系统架构的思考
【4月更文挑战第29天】在软件开发的世界中,代码不仅仅是一种交流工具,它更是构建艺术的基石。本文将探讨从基本函数编写到整个系统架构设计的过程中所涉及的技术细节与感悟。我们将穿梭于代码的海洋,体会那些看似简单却蕴含深意的编程原则,以及如何在宏观与微观之间寻找平衡,打造出既优雅又高效的系统。
云计算架构:Azure]比较流,逻辑应用(Logic App),函数和 WebJobs
云计算架构:Azure]比较流,逻辑应用(Logic App),函数和 WebJobs
多模态如何自监督?爱丁堡等最新「自监督多模态学习」综述:目标函数、数据对齐和模型架构
多模态如何自监督?爱丁堡等最新「自监督多模态学习」综述:目标函数、数据对齐和模型架构
865 0
Serverless架构——Faas——函数生命周期
Serverless架构——Faas——函数生命周期自制脑图, 介绍了冷启动,热启动,整个函数的运行过程可以分为四个阶段,
227 0
Serverless架构——Faas——函数生命周期
Serverless架构——函数及服务和FaaS 函数的两种调用方式
Serverless架构——函数及服务和FaaS 函数的两种调用方式自制脑图, 函数及服务,通俗来说就是我们可以写一个函数,在该函数内执行业务逻辑,函数由faas平台运行, FaaS 函数的两种调用方式:同步调用和异步调用
317 0
Serverless架构——函数及服务和FaaS 函数的两种调用方式
【Android 逆向】函数拦截 ( ARM 架构下的插桩拦截 | 完整代码示例 )
【Android 逆向】函数拦截 ( ARM 架构下的插桩拦截 | 完整代码示例 )
233 0

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等