如何解决Linq多条件组合问题
发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章主要为大家展示了"如何解决Linq多条件组合问题",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"如何解决Linq多条件组合问题"这篇文章吧。多种查询
千家信息网最后更新 2025年11月13日如何解决Linq多条件组合问题
这篇文章主要为大家展示了"如何解决Linq多条件组合问题",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"如何解决Linq多条件组合问题"这篇文章吧。
多种查询评价的条件:
1.Linq多条件之查询类型:
收到的评价_买家给我的评价,收到的评价_卖家给我的评价,给出的评价_我给买家的评价,给出的评价_我给卖家的评价
public enum OpinionSearchType { 收到的评价_买家给我的评价 = 0, 收到的评价_卖家给我的评价 = 1, 给出的评价_我给买家的评价 = 2, 给出的评价_我给卖家的评价 = 3 }2.Linq多条件之评价类型:
全部,好评,中评,差评
public enum OpinionType { 全部 = 0, 好评 = 1, 中评 = 2, 差评 = 3 }3.Linq多条件之评价查询时间:
全部,一个星期内,一个月以内,六个月以内,六个月以外
public enum OpinionTime { 全部 = 0, 一个星期内 = 1, 一个月以内 = 2, 六个月以内 = 3, 六个月以外 = 4 }由于缓存的需要,要把Expression完成之后再传到接口那边获取相应的List<评价意见>.按照这样的看的话,
总共3个条件, 13个子条件, 排列组合之后, 会有80种的组合. - - 真的一个个组合去写的话,还真是累死人了..
左思右想,***的方法就是把3个条件都拆开来,完成不同的Expression,到***再把三个条件组合在一起成为一个新的Expression.网上找到的比较都只是单条件的Parameter, 查了MSDN,才知道有个Expression.And(left, right)可以完成我的需求.利用.net3.5的扩展方法写成了一个组合Expression的方法,再重载了几个多参数的表达式,如下:
#region 表达式 public static Expression ContactExpressions(this Expression exp, params Expression[] exps) { foreach (var e in exps) { if (null == e) continue; exp = Expression.And(exp, e); } return exp; } public static Expression ContactExpressions(this Expression exp, params Expression[] exps) { foreach (var e in exps) { if (null == e) continue; exp = Expression.And(exp, e); } return (Expression)exp; } public static Expression ContactExpressions(this Expression exp, params Expression[] exps) { foreach (var e in exps) { if (null == e) continue; exp = Expression.And(exp, e); } return (Expression)exp; } public static Expression ContactExpressions(this Expression exp, params Expression[] exps) { foreach (var e in exps) { if (null == e) continue; exp = Expression.And(exp, e); } return (Expression)exp; } public static Expression ContactExpressions(this Expression exp, params Expression[] exps) { foreach (var e in exps) { if (null == e) continue; exp = Expression.And(exp, e); } return (Expression)exp; } #endregion 有了这几个方法进行Linq多条件查询,原本的需求就可以迎刃而解了:
Expression> expSearchType = null; Expression > expOpinionType = null; Expression > expOpinionTime = null; switch (searchType) { case OpinionSearchType.给出的评价_我给买家的评价: expSearchType = Y => Y.UserID == userID && !Y.IsSeller; break; case OpinionSearchType.给出的评价_我给卖家的评价: expSearchType = Y => Y.UserID == userID && Y.IsSeller; break; case OpinionSearchType.收到的评价_买家给我的评价: expSearchType = Y => Y.ToUserID == userID && !Y.IsSeller; break; case OpinionSearchType.收到的评价_卖家给我的评价: expSearchType = Y => Y.ToUserID == userID && !Y.IsSeller; break; } switch (opinType) { case OpinionType.好评: expOpinionType = Y => Y.OpinionType == 0; break; case OpinionType.中评: expOpinionType = Y => Y.OpinionType == 1; break; case OpinionType.差评: expOpinionType = Y => Y.OpinionType == 2; break; } switch (opinTime) { case OpinionTime.一个星期内: expOpinionTime = Y => (DateTime.Now - Y.OpinionTime).Days <= 7; break; case OpinionTime.一个月以内: expOpinionTime = Y => (DateTime.Now - Y.OpinionTime).Days <= 30; break; case OpinionTime.六个月以内: expOpinionTime = Y => (DateTime.Now - Y.OpinionTime).Days <= 180; break; case OpinionTime.六个月以外: expOpinionTime = Y => (DateTime.Now - Y.OpinionTime).Days > 180; break; } //GetPaged(params) 这个方法是用来获取列表并支持缓存保存的. return GetPaged(expSearchType.ContactExpressions (expOpinionType, expOpinionTime), userID.UserTablePrefx(), true, pageIndex, pageSize);
以上是"如何解决Linq多条件组合问题"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
评价
条件
组合
买家
卖家
方法
查询
问题
内容
好评
星期
篇文章
类型
缓存
表达式
需求
学习
帮助
不同
迎刃而解
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
adil网络技术
达梦数据库版本查看命令
数据库ddl语言包括哪些
无线电网络技术课后题
更新链接服务器数据库
广东数据库日志审计服务器
上海炫客网络技术有限公司
服务器 密码表 管理
sql数据库驱动器
网络技术质量服务
sql对数据库的管理
怀旧服服务器会卡吗
服务器蓝屏怎么办
软件开发信息安全机制
上海综合软件开发代理价钱
网络安全模式重启
数据库系统中的基本运算题
惠州科信网络技术企业
2016网络安全和信息化委员会
酒店网络安全管理制度范本
c 服务器面试
澳大利亚 软件开发 人天
数据库告警字段
敏捷软件开发模式都有什么
山西通信软件开发服务应用
网络安全小结语
创建数据库列的步骤
采用mesh的数据库
无线网络技术及其应用
淮北网络安全宣传视频