EF动态拼接查询
1、业务中遇到个问题,需要查询如某表的id为1或者2或者3,这里是根据传递参数获取如:传递1,2或者1,3或者1,2,3这里在sql中很好拼接如下:
select * from table where id = or id= or name=3//3代表另一个字段
2、但是如果是EF语句就不好实现了,因为参数不是固定的,踌躇半天写出个很low的代码如下:
if (list.Length == )
{
if (list[] == "")
{
finalMainEvent = finalMainEvent.Where(i => i.EU_IsRemove == (int)PublicEnmu.IsOperate.Yes);
}
else
{
int curId = GetDicValue(list[]);
finalMainEvent = finalMainEvent.Where(i => i.Evt_EventSatus == curId);
}
}
else if (list.Length == )
{
finalMainEvent = finalMainEvent.Where(i => (i.EU_IsRemove == (int)PublicEnmu.IsOperate.Yes || i.Evt_EventSatus == || i.Evt_EventSatus == ));
}
else
{
if (list.Contains(""))
{
var cur = list.Where(i => !i.Contains("")).FirstOrDefault();
int curId = GetDicValue(cur);
finalMainEvent = finalMainEvent.Where(i => (i.EU_IsRemove == (int)PublicEnmu.IsOperate.Yes || i.Evt_EventSatus == curId));
}
else
{
finalMainEvent = finalMainEvent.Where(i => (i.Evt_EventSatus == || i.Evt_EventSatus == ));
}
}
虽然解决了问题,但是这样写扩展性太不好,如果不只有三个参数,有30个参数呢?
3、看了半天网络,看到个Expand方法可以实现,解决步骤如下:
A:首先通过Nuget下载Linqkit安装到对应项目
B:页面引入命名空间:using LinqKit;
C:添加扩展类如下:
public static class PredicateBuilder
{
public static Expression<Func<T, bool>> True<T>() { return f => true; }
public static Expression<Func<T, bool>> False<T>() { return f => false; } public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> expr1,
Expression<Func<T, bool>> expr2)
{
var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>
(Expression.OrElse(expr1.Body, invokedExpr), expr1.Parameters);
} public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expr1,
Expression<Func<T, bool>> expr2)
{
var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>
(Expression.AndAlso(expr1.Body, invokedExpr), expr1.Parameters);
}
}
D:修改逻辑如下:
if (list.Count() > )
{
var predicate = PredicateBuilder.False<NewEventListItem>();
foreach (var item in list)
{
if (item != "")
{
int curId = GetDicValue(list[]);
predicate = predicate.Or(a => a.Evt_EventSatus == curId); }
else
{
predicate = predicate.Or(a => a.EU_IsRemove == (int)PublicEnmu.IsOperate.Yes);
}
}
finalMainEvent = finalMainEvent.AsExpandable().Where(predicate);
}
注意1:这里要加入AsExpandable()方法或者.Expand(),否则会报错(在指定的 LINQ to Entities 查询表达式中未绑定参数“a”。)
注意2:上述代码False很重要,因为如果写为True会影响查询结果,类似如下效果:
select * from table where name='一班' or id=1 or id=2 or id=3
所以需要改为False实现如下效果:
select * from table where name='一班' and (id=1 or id=2 or id=3)
这样问题就解决了。参考文章:
http://www.albahari.com/nutshell/predicatebuilder.aspx
http://blog.csdn.net/laokaizzz/article/details/28439447
最近又发现一个纯依赖于表达式树的功能,无需任何插件(因为引用linqkit插件会在系统中该项目和引用该项目的其他项目的配置文件添加配置信息):
//使用表达式树方式
Expression<Func<NewEventListItem, bool>> total = i => false;
ParameterExpression paraExp = Expression.Parameter(typeof(NewEventListItem), "x");
Expression totalR = Expression.Constant(false);
foreach (var item in list)
{ if (item!="") { int curId = GetDicValue(item);
Expression status = Expression.Property(paraExp, typeof(NewEventListItem).GetProperty("Evt_EventSatus"));
Expression paraExp__Dm_GUID__Equal = Expression.Equal(Expression.Convert(status,typeof(int)), Expression.Constant(curId)); totalR = Expression.Or(paraExp__Dm_GUID__Equal, totalR);
}else
{
Expression status = Expression.Property(paraExp, typeof(NewEventListItem).GetProperty("EU_IsRemove"));
Expression paraExp__Dm_GUID__Equal = Expression.Equal(Expression.Convert(status, typeof(int)), Expression.Constant((int)PublicEnmu.IsOperate.Yes)); totalR = Expression.Or(paraExp__Dm_GUID__Equal, totalR);
}
} total = Expression.Lambda<Func<NewEventListItem, bool>>(totalR, paraExp);
var totalres = finalMainEvent.Where(total);
感谢!有不对的地方欢迎指正!
EF动态拼接查询的更多相关文章
- EF 拉姆达 动态拼接查询语句
EF 动态拼接查询语句 using System; using System.Collections.Generic; using System.IO; using System.Linq; usin ...
- mybatis 使用记录(二) 动态拼接查询条件
2016-12-16 阅读项目代码时,在项目的xml文件中发现如下写法: SELECT student_user_id FROM tbr_student_class WHERE 1=1 <if ...
- 用PredicateBuilder实现Linq动态拼接查询
在使用Linq查询的时候,特别是如果你在使用Entiry Framwork,有时会遇到动态查询的情况(客户的查询条件是不固定的拼接查询).我们能想到的第一方案应该是拼接SQL,的确这样是可以达到我们的 ...
- Linq to Entity 动态拼接查询条件(重点是OR)
public static class PredicateExtensions { /// <summary> /// 机关函数应用True时:单个AND有效,多个AND有效:单个OR无效 ...
- .NetCore 使用 Linq 动态拼接Expression表达式条件来实现 对EF、EF Core 扩展查询排序操作
相信在使用EF的时候对查询条件或者排序上的处理令人心烦,下面我们就来动态拼接表达式解决这一问题 当我们在查询中使用Where的时候可以看到如下参数 下面我们就来扩展 Expression<Fun ...
- Asp.net Core C#进行筛选、过滤、使用PredicateBuilder进行动态拼接lamdba表达式树并用作条件精准查询,模糊查询
在asp.net core.asp.net 中做where条件过滤筛选的时候写的长而繁琐不利于维护,用PredicateBuilder进行筛选.过滤.LInq配合Ef.core进行动态拼接lamdba ...
- linq里lambda写的join查询,并附加动态拼接的条件,条件为enum类型的查询
因为查询条件不固定的原因,sql式的linq查询没法动态拼接条件. 网上搜的资料整理之后终于解决. 参考资料: enum使用 http://blog.csdn.net/slowlifes/articl ...
- SqlServer存储过程应用二:分页查询数据并动态拼接where条件
前言 开发中查询功能是贯穿全文的,我们来盘一盘使用存储过程分页查询,并且支持动态拼接where条件. 划重点:支持动态拼接where条件 对存储过程的使用有疑问的同学去[SqlServer存储过程的创 ...
- SQL Server-聚焦深入理解动态SQL查询(三十二)
前言 之前有园友一直关注着我快点出SQL Server性能优化系列,博主我也对性能优化系列也有点小期待,本来打算利用周末写死锁以及避免死锁系列的接着进入SQL Server优化系列,但是在工作中长时间 ...
随机推荐
- 【框架学习与探究之宿主服务--Topshelf】
前言 此文欢迎转载,原始链接地址:http://www.cnblogs.com/DjlNet/p/7603819.html 正文 原先也偶然见过这个关键词,当时只是有个大致了解貌似和WinServic ...
- JS使用默认图片代替页面上无法显示的图片
1.js方法: function replaceErrorImg(obj) { obj.src="images/common/error.bmp"; } 2.jquery绑定 $( ...
- FPGA在电平接口领域的应用
电子技术的发展,产生了各种各样的电平接口. TTL电平: TTL电平信号之所以被广泛使用,原因是因为:通常我们采用二进制来表示数据.而且规定,+5V等价于逻辑"1",0V等价于逻辑 ...
- BS4爬取糗百
-- coding: cp936 -- import urllib,urllib2 from bs4 import BeautifulSoup user_agent='Mozilla/5.0 (Win ...
- HDU1068 二分匹配 独立集
前边和后边性别不同!!!不然NP了 Girls and Boys Problem Description the second year of the university somebody star ...
- 原生API实现拖拽上传文件实践
功能: 拖拽上传文件.图片,上传的进度条,能够同时上传多个文件. 完整的demo地址:https://github.com/qcer/FE-Components/tree/master/QDrag 涉 ...
- 热门开源项目:Guns-后台管理系统
Guns基于SpringBoot,致力于做更简洁的后台管理系统,完美整合springmvc + shiro + mybatis-plus + beetl!Guns项目代码简洁,注释丰富,上手容易,同时 ...
- chromium源码阅读--进程的Message Loop
上一篇总结了chromium进程的启动,接下来就看线程的消息处理,这里的线程包含进程的主进程. 消息处理是由base::MessageLoop中实现,消息中的任务和定时器都是异步事件的. 主要如下几点 ...
- 张高兴的 Windows 10 IoT 开发笔记:BMP180 气压传感器
注意:海拔高度仅供参考 GitHub : https://github.com/ZhangGaoxing/windows-iot-demo/tree/master/BMP180Demo
- Django安装以及介绍
安装django说先需要安装python环境,因为他是依赖于python环境运行的 最好再安装pycharm,一款强大的开发工具,里面有各种开发工具的集成 在Windows先安装: 首先进入cmd命令 ...