简单解决Linq多条件组合问题<转>
本文笔者用清晰的实例,解决了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
bool>> expSearchType = null; - Expression
bool>> expOpinionType = null; - Expression
bool>> 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
bool>(expOpinionType, expOpinionTime), - userID.UserTablePrefx(), true, pageIndex, pageSize);
以上就是通过Linq实例解析Linq的另类用法,然后解决Linq多条件组合问题。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?