C#;麻烦好心人:如何实现dataGridView的筛选?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#;麻烦好心人:如何实现dataGridView的筛选?相关的知识,希望对你有一定的参考价值。

从txt导入到dataGridView中已经实现用的datatable。现在的问题是:
例如:002001 张三
002003 李四
001009 王五
007112 赵六
002779 如花
我想实现在textbox中输入2然后dataGridView中只显示第一 二 五行,即002开头的。因为已经导入完毕,我希望尽量不要动导入部分,而是直接筛选将不需要的隐藏,可行吗?若可行如何实现?若不可行有什么方法呢?
之前得到好心人提示用select:
DataTable tb = new DataTable();
DataColumn cl = new DataColumn();
cl.ColumnName = "userName";
cl.DataType = typeof(string);
tb.Columns.Add(cl);
for (int i = 0; i < 20; i++)

DataRow row = tb.NewRow();
if (i % 2 == 0)

row["userName"] = "zl" + i;

else

row["userName"] = "002" + i;

tb.Rows.Add(row);

DataRow[] rows= tb.Select("userName like '002%'");
我试了半天,没达到预期效果,求解答!

参考技术A 在你的筛选按钮里面
假如现在你的表格的datasource对应了一个datatable dt
那现在你定义一个dataview dv=new dataview(dt)
然后 dv.filter=string.format("列明 like '%0%'",textbox的值);
datagridview1.datasource=dv;追问

我试了下可行,只是还不完全是我想要的他是002XXX或者0023XX,即筛选的是特定第二位,或第二位和第三位,是不是在 '%0%'中作修改呢?怎么改?网上这块东西不多,麻烦您了!

追答

%号代表若干字符
如果是002开头
string.format("列明 like '0%'","002");

下面的写法是等于
string.format("列明 = '0'","002");

本回答被提问者采纳

winform中的DataGridView如何实现分页(C#)

能跟讲讲实现思路吗 不要代码

常用分页一般有两种
一是在数据库写存储过程,或利用sql语句,每次只取出N条数据。
二是将数据一次性全取出来,然后利用程序来进行分页。
第一种在数据量比较大的时候性能好点。
希望你能明白。
参考技术A 这个要添加 DataGridView 控件的功能
写一个“用户控件”,继承DataGridView
public partial class UserControl1 : DataGridView
然后再添加一些翻页的方法
参考技术B 应该在后台就实现分页。DataGridView显示分页数据就可以了。 参考技术C http://www.cnblogs.com/sayu115/archive/2007/10/12/922115.html 参考技术D 你可以再视图下面放按钮,上一页下一页这些,然后放lable用于显示当前页和总页数也方便以后获取当前页数
方法一:查询出所有数据,获取你数据源的总行数,然后用你的总行数除以一行显示的数量, 得出的就是你的总页数
第一次进入当前页肯定是1在绑定数据数据时根据当前页和行数从你的数据源中取值,然后将取出的数据绑定你的DataGridView
在点击下一页或者上一页这些时++或--你的当前页,当然最后一页和第一页的时要进行判断的,否则就要出错了
方法二:写一个存储过程,传入当前页和每页行数,sql和oracle等数据库都有标识列,以此作为条件,只取出一部分数据绑定到DataGridView中,每一次点击按钮时,调用该存储过程获取数据,优势是在大数据量时查询效率比第一种方法效率高,并且在数据结构发生改变时方便维护,可以只修改存储过程

以上是关于C#;麻烦好心人:如何实现dataGridView的筛选?的主要内容,如果未能解决你的问题,请参考以下文章

C# DataGridView如何显示查询数据?

C#编写的一个界面 怎样实现dataGridView1里的内容在上面显示?

c#如何实现DataGridView翻页显示

winform中的DataGridView如何实现分页(C#)

如何实现c# winform DataGridView添加一行,添加数据后,保存到数据库?

如何实现c# winform DataGridView添加一行,添加数据后,保存到数据库