欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-03-06 20:59:38
本篇适合于规模较小的数据量,对于大数据量,需要用另外的方式,见下一篇   首先,从网上搜,是必不可少的,大概了解了一下linq 多条件组合查询的方向,就开始动手了,首先,写...
本篇适合于规模较小的数据量,对于大数据量,需要用另外的方式,见下一篇
  首先,从网上搜,是必不可少的,大概了解了一下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,鄙视这些垃圾网站.还有写手.
希望各位初学者能从我的文章中获益!