Linq动态查询与模糊查询(带源码示例)
2008-08-03 20:26
369 查看
最近有个项目用Linq做的,有个复合搜索模糊查询的功能,有点麻烦,绕了好几个弯,最后是解决了,在这里分享一下我的处理过程,如果大家有更好的办法也请给我介绍一下。我用Linq还不熟,好多东西边查资料边做的。
应用场景如下图,多条件复合搜索,很常见吧(但Linq搞这个还真是麻烦):
1 /// <summary>
2 /// 构造函数使用True时:单个AND有效,多个AND有效;单个OR无效,多个OR无效;混合时写在AND后的OR有效
3 /// 构造函数使用False时:单个AND无效,多个AND无效;单个OR有效,多个OR有效;混合时写在OR后面的AND有效
4 /// </summary>
5 public static class PredicateExtensions
6 {
7 public static Expression<Func<T, bool>> True<T>() { return f => true; }
8
9 public static Expression<Func<T, bool>> False<T>() { return f => false; }
10
11 public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
12 {
13 var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());
14
15 return Expression.Lambda<Func<T, bool>>(Expression.Or(expression1.Body, invokedExpression), expression1.Parameters);
16 }
17
18 public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
19 {
20 var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());
21
22 return Expression.Lambda<Func<T, bool>>(Expression.And(expression1.Body, invokedExpression), expression1.Parameters);
23 }
24 }
附带完整源代码示例
应用场景如下图,多条件复合搜索,很常见吧(但Linq搞这个还真是麻烦):
1 /// <summary>
2 /// 构造函数使用True时:单个AND有效,多个AND有效;单个OR无效,多个OR无效;混合时写在AND后的OR有效
3 /// 构造函数使用False时:单个AND无效,多个AND无效;单个OR有效,多个OR有效;混合时写在OR后面的AND有效
4 /// </summary>
5 public static class PredicateExtensions
6 {
7 public static Expression<Func<T, bool>> True<T>() { return f => true; }
8
9 public static Expression<Func<T, bool>> False<T>() { return f => false; }
10
11 public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
12 {
13 var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());
14
15 return Expression.Lambda<Func<T, bool>>(Expression.Or(expression1.Body, invokedExpression), expression1.Parameters);
16 }
17
18 public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
19 {
20 var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());
21
22 return Expression.Lambda<Func<T, bool>>(Expression.And(expression1.Body, invokedExpression), expression1.Parameters);
23 }
24 }
附带完整源代码示例
相关文章推荐
- Linq动态查询与模糊查询(带源码示例)
- Linq动态查询与模糊查询(带源码示例)
- Linq动态查询与模糊查询 ---转
- 【菜鸟看框架】——Linq实现动态模糊查询
- 【菜鸟看框架】——Linq实现动态模糊查询
- linq实现动态查询和模糊查询
- Linq动态查询与模糊查询
- linq中动态模糊查询
- LinqToSql 动态查询条件,join, isnull 综合示例
- Ext.grid.EditorGridPanel单元格内套用下拉列表,且列表数据为动态加载,支持模糊查询,有描述信息
- mybatis中使用动态参数进行模糊查询
- LINQ体验(17)——LINQ to SQL语句之动态查询
- 【Mybatis学习总结六】动态SQL与模糊查询
- C#中linq学习(Linq查询操作中的类型关系)示例
- Linq排序、分组、模糊查询、调用外部方法、直接执行SQL语句、事务、修改数据
- myBatis学习笔记(6)——动态SQL & 模糊查询
- LINQ体验(17)——LINQ to SQL语句之动态查询
- MyBatis实现动态查询、模糊查询功能
- 动态Linq的逻辑与和逻辑或的条件查询
- 动态生成的chosen实现模糊查询