当前位置: 移动技术网 > IT编程>开发语言>.net > linq to sql中,如何解决多条件查询问题,答案,用表达式树!

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

2017年12月12日  | 移动技术网IT编程  | 我要评论

我们结婚了20111015,国家高速公路网,张满法

本篇适合于规模较小的数据量,对于大数据量,需要用另外的方式,见下一篇
  首先,从网上搜,是必不可少的,大概了解了一下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,鄙视这些垃圾网站.还有写手.
希望各位初学者能从我的文章中获益!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网