如何解决Linq多条件组合问题
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章主要为大家展示了"如何解决Linq多条件组合问题",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"如何解决Linq多条件组合问题"这篇文章吧。多种查询
千家信息网最后更新 2025年02月03日如何解决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 ExpressionContactExpressions(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安全错误
数据库的锁怎样保障安全
数据库国家相关技术标准
数据库调研报告大学
网络安全职责划分和落实工作
橙色云互联网科技有限公司
车牌识别服务器
ntp时间服务器的ip
用友t6 数据库win7
安装db2数据库客户端
中国网络安全贡献一份力量
数据库关于考试时间的函数
毕业论文会传到万芳数据库吗
联想服务器培训
浦东新区市场软件开发销售方法
长寿区一站式网络技术服务活动
网络安全首要威胁是什么
启明星辰面试网络安全
浙江网络技术培训班
我的世界软件开发商
亳州工程管理软件开发要多少钱
腾讯服务器可以登录千牛吗
%数据库中的意思
软件在本机上连不上数据库
筋斗鱼软件开发有限公司招聘
工业控制网络技术的心得体会
什么叫服务器的基线配置 知乎
下列哪个数据库对象能直接从
小学校园网络安全宣传知识
未转变者下载的服务器文件
服务器分离
2k22ps4连不上服务器