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,鄙视这些垃圾网站.还有写手.
希望各位初学者能从我的文章中获益!
首先,从网上搜,是必不可少的,大概了解了一下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,鄙视这些垃圾网站.还有写手.
希望各位初学者能从我的文章中获益!
上一篇: Android界面数据懒加载实现代码
下一篇: 利用java监听器实现在线人数统计