linq to sql中,如何解决多条件查询问题,答案,用表达式树!

 更新时间:2011年08月17日 23:39:36   作者:  
有个小项目中,用到了linq to sql,既然这样,想必需要做多条件组合查询了,虽然我对表达式树的研究也只是寥寥地,但除此方法,似乎别无他法,只好硬着头皮研究一下.
本篇适合于规模较小的数据量,对于大数据量,需要用另外的方式,见下一篇
  首先,从网上搜,是必不可少的,大概了解了一下linq 多条件组合查询的方向,就开始动手了,首先,写一个委托的方法:
复制代码 代码如下:

private bool GetCondition(FeedBack fb)
{
bool boolResult = true;
int f_type = Int32.Parse(ddlFType.SelectedValue);
int isClose = Int32.Parse(ddlIsClose.SelectedValue);
int isTrue = Int32.Parse(ddlIsTrue.SelectedValue);
string keyword = tbxKeyword.Text.FilterInjectStr();
if (f_type != 0)
{
boolResult &= fb.F_Type == f_type;
}
if (isClose != -1)
{
boolResult &= fb.IsClose == isClose;
}
if (isTrue != -1)
{
boolResult &= fb.IsTrue == isTrue;
}
if (!keyword.IsNullOrEmpty())
{
boolResult &= fb.ContentInfo.IndexOf(keyword) > -1;
}
return boolResult;
}

这里因为是做测试,我就全部把方法放在当前页面中了.
注意,此方法中的内容,可以根据实际情况进行改变,我这里做的是一个留言板的列表;
调用的方式,我这里列表是是绑定repeater控件的.
于是可以这样:
复制代码 代码如下:

private void ListDataBind()
{
Expression<Func<FeedBack,bool>> expr = n => GetCondition(n);
List<FeedBack> pageData = feedBacks.AllFeedBacks.Where(expr.Compile()).ToList();
FeedbackList.DataSource = pageData;
FeedbackList.DataBind();
}

注意,FeedBack是我的linq to sql的数据源表的对象名称.
另外,网站搜的一些答案有错误,例如会把我的Expression<Func<FeedBack,bool>>写成Expressionbool>>,NND,鄙视这些垃圾网站.还有写手.
希望各位初学者能从我的文章中获益!

相关文章

  • asp.net防止刷新时重复提交(可禁用工具条刷新按钮)

    asp.net防止刷新时重复提交(可禁用工具条刷新按钮)

    前段时间遇到了需要禁用刷新的需求,f5按钮就不说了,简单的js就能把它禁用,但是工具条上的刷新按钮却防止不了啊,不过本文介绍的一种方法却可以解决此问题,感兴趣的朋友可以了解下啊,希望本文对你有所帮助
    2013-01-01
  • .Net中生成二维的表格的代码 分享

    .Net中生成二维的表格的代码 分享

    找了很久才找到的在.NET中生成二维表格的代码,不敢独享,现在就贴出来给大家看看,相信对大家有所帮助。
    2013-07-07
  • Visual Studio for Mac版 初体验

    Visual Studio for Mac版 初体验

    这篇文章主要介绍了Visual Studio for Mac版 初体验,本文图文并茂给大家介绍的非常详细,需要的朋友可以参考下
    2017-05-05
  • asp.net静态方法弹出对话框实现思路

    asp.net静态方法弹出对话框实现思路

    为菜鸟所准备……其实就是弹出JavaScript小窗口,总得来说就是定义的一个DIV,感兴趣的朋友可以了解下,或许对你学习asp.net有所帮助
    2013-02-02
  • 使用 Salt + Hash 将密码加密后再存储进数据库

    使用 Salt + Hash 将密码加密后再存储进数据库

    如果你需要保存密码(比如网站用户的密码),你要考虑如何保护这些密码数据,象下面那样直接将密码写入数据库中是极不安全的,因为任何可以打开数据库的人,都将可以直接看到这些密码
    2012-12-12
  • .Net core下直接执行SQL语句并生成DataTable的实现方法

    .Net core下直接执行SQL语句并生成DataTable的实现方法

    .net core可以执行SQL语句,但是只能生成强类型的返回结果。这篇文章主要介绍了.Net core下直接执行SQL语句并生成DataTable的相关资料,需要的朋友可以参考下
    2016-11-11
  • ashx介绍以及ashx文件与aspx文件之间的区别

    ashx介绍以及ashx文件与aspx文件之间的区别

    这篇文章主要介绍了ashx以及ashx文件与aspx文件之间的区别。需要的朋友可以过来参考下,希望对大家有所帮助
    2013-12-12
  • asp.net Reporting Service在Web Application中的应用

    asp.net Reporting Service在Web Application中的应用

    由于我们这个项目中使用微软的报表服务(Reporting Services)作为报表输出工具,本人也对它进行一点点研究,虽没有入木三分,但这点知识至少可以在大部分Reporting Service的场景中应用。
    2008-11-11
  • asp.net web api2设置默认启动登录页面的方法

    asp.net web api2设置默认启动登录页面的方法

    这篇文章主要介绍了asp.net web api2设置默认启动登录页面的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-09-09
  • ASP.NET MVC生成静态页面的方法

    ASP.NET MVC生成静态页面的方法

    对于网站来说,生成纯html静态页面除了有利于seo外,还可以减轻网站的负载能力和提高网站性能。本篇文章主要介绍了ASP.NET MVC生成静态页面的方法,有兴趣的可以了解一下。
    2017-03-03

最新评论