linq 动态拼接查询条件 扩展方法
2016-05-10 17:13
441 查看
public static class PredicateBuilder
{
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>> expr1,
Expression<Func<T, bool>> expr2)
{
var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>
(Expression.Or(expr1.Body, invokedExpr), expr1.Parameters);
}
public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expr1,
Expression<Func<T, bool>> expr2)
{
var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>
(Expression.And(expr1.Body, invokedExpr), expr1.Parameters);
}
}
调用例子
protected void btnQuery_Click(object sender, EventArgs e)
{
var predicate = PredicateBuilder.True<Products>();
string sProductName = txtProductName.Text;
if (sProductName != "")
{
predicate = predicate.And(p=>p.ProductName.Contains(sProductName));
}
if (ddlCategory.SelectedIndex != 0)
{
predicate = predicate.And(p => p.CategoryID == Convert.ToInt32(ddlCategory.SelectedValue));
}
gvDemo.DataSource = dc.Products.Where(predicate).Select(p => new { p.ProductName,p.Categories.CategoryName,p.UnitPrice});
gvDemo.DataBind();
}
{
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>> expr1,
Expression<Func<T, bool>> expr2)
{
var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>
(Expression.Or(expr1.Body, invokedExpr), expr1.Parameters);
}
public static Expression<Func<T, bool>> And<T>(this Expression<Func<T, bool>> expr1,
Expression<Func<T, bool>> expr2)
{
var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
return Expression.Lambda<Func<T, bool>>
(Expression.And(expr1.Body, invokedExpr), expr1.Parameters);
}
}
调用例子
protected void btnQuery_Click(object sender, EventArgs e)
{
var predicate = PredicateBuilder.True<Products>();
string sProductName = txtProductName.Text;
if (sProductName != "")
{
predicate = predicate.And(p=>p.ProductName.Contains(sProductName));
}
if (ddlCategory.SelectedIndex != 0)
{
predicate = predicate.And(p => p.CategoryID == Convert.ToInt32(ddlCategory.SelectedValue));
}
gvDemo.DataSource = dc.Products.Where(predicate).Select(p => new { p.ProductName,p.Categories.CategoryName,p.UnitPrice});
gvDemo.DataBind();
}
相关文章推荐
- Maven学习13之覆盖率测试
- SSH无密码登录
- RabbitMQ 集群与高可用配置
- 简单解析JavaScript中的__proto__属性
- 第十一周阅读程序(补充)----(3.2)
- 连接属性
- Java语言使用HttpClient模拟浏览器登录
- Android4.0 Launcher 源码分析3——WorkSpace结构(滑动)
- Web Uploader文件上传插件使用详解
- Part2:Unity学习笔记十一 - Space Shooter
- Python实现ping指定IP
- RAM测评优化方案
- 用JSONP实现跨域请求
- 沉浸式状态栏实现
- Lock与synchronized 的区别
- Android NDK开发Crash错误定位
- spark 使用中会遇到的一些问题及解决思路
- LocalBroadcastManager
- Java语言使用HttpClient模拟浏览器登录
- vim 配置(ma6174 + YCM)