如何解决Linq多条件组合问题
发表于:2024-11-22 作者:千家信息网编辑
千家信息网最后更新 2024年11月22日,这篇文章主要为大家展示了"如何解决Linq多条件组合问题",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"如何解决Linq多条件组合问题"这篇文章吧。多种查询
千家信息网最后更新 2024年11月22日如何解决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安全错误
数据库的锁怎样保障安全
公网服务器怎么看
做软件开发的买什么电脑好
实用网络技术答案
给孩子上dna数据库
有哪几类数据库索引
南京嘉锋网络技术有限公司
当代高校网络安全现状
数据库中如何增加100行数据
上海东旦软件开发有限
计算机网络安全专业是工科
网络安全对比软件开发
魔兽怀旧服服务器维护多长时间
尚唯工程技术数据库
东南大学本科网络安全好学吗
登封5g数据库
墨迹天气网络安全事件
余姚直销软件开发流程
云服务器练习linux怎么样
方舟手游服务器送新人风神
网络安全产业股票
网络安全手抄报电子版素材
如何安装sql数据库软件
中国网络安全使用
安卓加密数据库文件怎么打开
上海东旦软件开发有限
湘潭软件开发制作
权限 角色 数据库设计
杭州富柠网络技术有限公司
网络安全教育讲话稿百度文库
图们天气预报软件开发