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 |


浙公网安备 33010602011771号