winform datagridview实时更新显示查询结果
2016-04-24 18:14
387 查看
datagridview是winform编程上很常见也很常用的控件之一,下面就根据一个小需求来展示一下datagridview是怎么实时刷新显示查询结果的。
根据需要,此程序主要是用来查询,并不赋予修改的权限,所以以下属性必须设置。
AllowUserToAddRows
AllowUserToDeleteRows
AllowUserToResizeColumns
AllowUserToResizeRows
上面四项属性均设置为False。
这个时候你会发现,列头都挤在了最左边,想让它居中充满显示,怎么办呢?
很简单,把AotuSizeColumnsMode设置为Fill即可。
好了,下面我们开始写程序运行的各种事件。
1、写一个公共类,zb_class,包含datagridview的显示方法。
方法代码:
首先声明一个连接数据库的静态变量Zb_ConStr
然后写加载datagridview的方法
2、双击打开程序时,让datagridview显示所有的电话信息。
3、datagridview根据输入的是汉字还是拼音助记码(即科室名称的拼音首字母)自动搜索并显示出来。
4、点击按钮的事件和输入框的TextChanged事件相同,再此不再赘述。
目标界面
界面图片 |
---|
说明:这个界面并不是VS系统的界面,是用到了第三方的控件实现的 |
实现过程
这个界面用到了Groupbox、label、button和datagridview这几个控件。一、属性设置
每个控件的属性设置在这里就不再赘述了,主要说一下datagridview的设置。根据需要,此程序主要是用来查询,并不赋予修改的权限,所以以下属性必须设置。
AllowUserToAddRows
AllowUserToDeleteRows
AllowUserToResizeColumns
AllowUserToResizeRows
上面四项属性均设置为False。
二、列头设置
列头设置如图 |
---|
Tips:在DataPropertyName这里添上对应数据库字段的列名 |
很简单,把AotuSizeColumnsMode设置为Fill即可。
好了,下面我们开始写程序运行的各种事件。
三、事件实现
上面的属性都设置完了,下面我们开始写这个程序的实现步骤。1、写一个公共类,zb_class,包含datagridview的显示方法。
方法代码:
首先声明一个连接数据库的静态变量Zb_ConStr
public static string zb_ConStr = "Server=.;User Id=sa;Pwd=sa;DataBase=test";
然后写加载datagridview的方法
public static DataView sqldataset(string sqlstr, string tablename)//加载数据表 { SqlConnection zb_myconn = new SqlConnection(zb_ConStr); SqlDataAdapter da = new SqlDataAdapter(sqlstr, zb_myconn); DataSet ds = new DataSet(); da.Fill(ds, tablename); DataView dv = new DataView(ds.Tables[tablename]); dv.AllowNew = false; return dv; }
2、双击打开程序时,让datagridview显示所有的电话信息。
/// <summary> /// 启动时的事件 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void CheckPhoneNum_Load(object sender, EventArgs e) { try{ string all_num = "select * from TEL_NUM"; //TEL_NUM是数据库里的电话号码表 NUM_DGV.DataSource = zb_class.sqldataset(all_num, "默认加载全部号码"); } catch{ MessageBox.Show("连接数据库失败!没有数据!"); } }
3、datagridview根据输入的是汉字还是拼音助记码(即科室名称的拼音首字母)自动搜索并显示出来。
/// <summary> /// 输入汉字或者助记码,datagridview自动搜索显示 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void ksmc_textbox_TextChanged(object sender, EventArgs e) { string hanzi = "select * from TEL_NUM where KSMC like'%"+ksmc_textbox.Text.Trim()+"%'"; string zjm = "select * from TEL_NUM where ZJM like'%"+ksmc_textbox.Text.Trim()+"%'"; Regex rx = new Regex("^[\u4E00-\u9FA5]+$"); //判断输入的是拼音助记码还是汉字 if(rx.IsMatch(ksmc_textbox.Text)) { NUM_DGV.DataSource=zb_class.sqldataset(hanzi,"输入的是汉字"); } else { NUM_DGV.DataSource = zb_class.sqldataset(zjm, "输入的是汉字"); } }
4、点击按钮的事件和输入框的TextChanged事件相同,再此不再赘述。
总结
datagridview自动刷新显示的根本在于zb_class类里的sqldataset方法和TextChanged事件的结合运用。相关文章推荐
- flex 控件的重要属性
- winform绑定快捷键的方法
- Delphi控件ListView的属性及使用方法详解
- C#实现WinForm捕获最小化事件的方法
- WinForm之BindingSource基础操作实例教程
- DataGridView控件详细介绍
- 在winform下实现左右布局多窗口界面的方法之续篇
- WinForm相对路径的陷阱
- winform实现拖动文件到窗体上的方法
- web下载的ActiveX控件自动更新
- WinForm实现程序一段时间不运行自动关闭的方法
- C#采用Winform实现类似Android的Listener
- WinForm自定义控件应用实例
- WinForm实现为TextBox设置水印文字功能
- C# WinForm 判断程序是否已经在运行,且只允许运行一个实例,附源码
- C#设置WinForm中DataGrid列的方法(列宽/列标题等)
- winform 实现控制输入法
- WinForm实现最小化到系统托盘方法实例详解
- WinForm中的几个实用技巧汇总
- WinForm实现按名称递归查找控件的方法