How to filter DataView based on multiple inputs

瘦欲@ 提交于 2019-11-28 14:24:15

You can use something like light t-sql when defining RowFilter.

One idea is:

FilterDataView.RowFilter = "name like '%habjan%' and city like '%new york%'"

Here you can find a good article about RowFilter syntax: DataView RowFilter Syntax

For what you need you will have to build row filter based on entered fields.

    StringBuilder sb = new StringBuilder();

    if (tb1.Text.Length > 0)
    {
       sb.Append("name like '%" + tb1.Text + "%'");
    }

    if (tb2.Text.Length > 0)
    {
       if(sb.Length > 0)
       {
           sb.Append(" and ");
       }

       sb.Append("city like '%" + tb2.Text + "%'");
    }
    //.... and so on...

    FilterDataView.RowFilter = sb.ToString();

Okay, Linq to SQL is going to be your friend.

You need to learn the syntax, and there are a few different forms, but you can recreate your query in this way:

var x = from T in db.Table
        where [usual where stuff goes here];

Then, you can test each textbox and do the following:

if (TextBox1.Text != null) x.Where(w => w.field1 == val1);

The nice thing is you can layer those Where clauses one at a time. Then just bind your object to the var.

[objectname].Datasource = x; 
[objectname].Databind();

That should solve your problem.

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!