linq动态多条件查询
2011-06-18 00:22
387 查看
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Linq.Expressions;
namespace ClassTest
{
public static class PredicateExtensions
{
public static Expression<Func<T, bool>> True<T>() { return f => true; }
public static Expression<Func<T, bool>> False<T>() { return f => false; }
public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
{
var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>(Expression.Or(expression1.Body, invokedExpression), expression1.Parameters);
}
public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
{
var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>(Expression.And(expression1.Body, invokedExpression), expression1.Parameters);
}
}
public class Test
{
struct Product
{
public int productID;
public string productName;
public string productDesc;
}
static void Main()
{
List<Product> products = new List<Product>();
Product product;
product.productID = 1;
product.productName = "aaa";
product.productDesc = "good aaa";
products.Add(product);
product.productID = 1;
product.productName = "bbb";
product.productDesc = "good bbb";
products.Add(product);
product.productID = 3;
product.productName = "ccc";
product.productDesc = "good ccc";
products.Add(product);
product.productID = 4;
product.productName = "ddd";
product.productDesc = "good ddd";
products.Add(product);
var predicate = PredicateExtensions.True<Product>();
int id=1;
string name=null;
string desc=null;
if (id != 0)
predicate=predicate.And(p => p.productID == id);
if (!string.IsNullOrEmpty(name))
predicate=predicate.And(p => p.productName.Contains(name));
if (!string.IsNullOrEmpty(desc))
predicate=predicate.And(p => p.productDesc.Contains(desc));
var proList = products.AsQueryable().Where(predicate).Select(p=>p);
foreach (var prod in proList)
Console.WriteLine("{0} {1} {2}",prod.productID,prod.productName,prod.productDesc);
}
}
}
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Linq.Expressions;
namespace ClassTest
{
public static class PredicateExtensions
{
public static Expression<Func<T, bool>> True<T>() { return f => true; }
public static Expression<Func<T, bool>> False<T>() { return f => false; }
public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
{
var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>(Expression.Or(expression1.Body, invokedExpression), expression1.Parameters);
}
public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expression1, Expression<Func<T, bool>> expression2)
{
var invokedExpression = Expression.Invoke(expression2, expression1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>(Expression.And(expression1.Body, invokedExpression), expression1.Parameters);
}
}
public class Test
{
struct Product
{
public int productID;
public string productName;
public string productDesc;
}
static void Main()
{
List<Product> products = new List<Product>();
Product product;
product.productID = 1;
product.productName = "aaa";
product.productDesc = "good aaa";
products.Add(product);
product.productID = 1;
product.productName = "bbb";
product.productDesc = "good bbb";
products.Add(product);
product.productID = 3;
product.productName = "ccc";
product.productDesc = "good ccc";
products.Add(product);
product.productID = 4;
product.productName = "ddd";
product.productDesc = "good ddd";
products.Add(product);
var predicate = PredicateExtensions.True<Product>();
int id=1;
string name=null;
string desc=null;
if (id != 0)
predicate=predicate.And(p => p.productID == id);
if (!string.IsNullOrEmpty(name))
predicate=predicate.And(p => p.productName.Contains(name));
if (!string.IsNullOrEmpty(desc))
predicate=predicate.And(p => p.productDesc.Contains(desc));
var proList = products.AsQueryable().Where(predicate).Select(p=>p);
foreach (var prod in proList)
Console.WriteLine("{0} {1} {2}",prod.productID,prod.productName,prod.productDesc);
}
}
}
相关文章推荐
- linq里lambda写的join查询,并附加动态拼接的条件,条件为enum类型的查询
- 也说Linq动态条件查询
- Linq to sql 实现多条件的动态查询(方法一)
- linq 优缺点、多重条件动态查询
- linq 动态拼接查询条件 扩展方法
- Linq to SQL 多条件动态组合查询(实战篇)
- linq to sql的多条件动态查询(下)
- linq to sql的多条件动态查询(下)
- LINQ to SQL 运行时动态构建查询条件
- Linq to sql 实现多条件的动态查询(方法一)
- 使用Python读取TestTrack记录- Part3 动态生成Linq to xml查询语句筛选条件
- Linq动态条件查询
- LINQ to SQL 运行时动态构建查询条件
- Linq to sql 实现多条件的动态查询(方法二)
- linq to sql的多条件动态查询
- LINQ动态条件查询(一)
- linq to sql的多条件动态查询(上)
- 用Linq 实现动态多条件查询
- LINQ to SQL 运行时动态构建查询条件
- LINQ to Entities 多条件动态查询