C# winform datagridview实时更新显示查询结果

datagridview是winform编程上很常见也很常用的控件之一,下面就根据一个小需求来展示一下datagridview是怎么实时刷新显示查询结果的。

目标界面

界面图片
查电话号码的程序界面.png
说明:这个界面并不是VS系统的界面,是用到了第三方的控件实现的

实现过程

这个界面用到了Groupbox、label、button和datagridview这几个控件。

一、属性设置

每个控件的属性设置在这里就不再赘述了,主要说一下datagridview的设置。

根据需要,此程序主要是用来查询,并不赋予修改的权限,所以以下属性必须设置。

AllowUserToAddRows
AllowUserToDeleteRows
AllowUserToResizeColumns
AllowUserToResizeRows

上面四项属性均设置为False。

二、列头设置

列头设置如图
添加各个列的名称.png
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事件的结合运用。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容

  • 1、窗体 1、常用属性 (1)Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体。 ...
    Moment__格调阅读 4,545评论 0 11
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,056评论 25 707
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,651评论 18 139
  • 《裕语言》速成开发手册3.0 官方用户交流:iApp开发交流(1) 239547050iApp开发交流(2) 10...
    叶染柒丶阅读 26,591评论 5 19
  • 引序 忆江南 忆江南 江南是个水乡之城 ,白居易诗下的江南无谓是最好的证明了 江南的优美环境 在这美好的环境下却不...
    会哭的猫w阅读 217评论 0 0