C# 数据库dataGridView刷新数据和主外键判断

本文主要讲诉在使用VS2012+SQL Server数据库做系统中,通常会遇到几个问题.使用dataGridView控件在修改、删除、插入数据后,怎样刷新数据显示操作后的结果.同时在对数据操作时通常会判断数据的主键是否存在或重复,判断外键是否重复,这几个问题我推荐使用函数的形式完成,同时推荐一个操作格式,下面将详细介绍.

一.dataGridView刷新数据

如下图所示,在数据库中删除一个数据或插入一个数据,我们都希望能够在左边的dataGridView控件中显示操作后的内容,而使用dataGridView1.Refresh()刷新只是刷新页面重绘控件,没有从数据库里读取内容.所以我们需要重新绑定数据,点击按钮故障信息删除后,实现重新读取数据库的值,并显示在控件dataGridView中即可.而这里我采用自定义函数实现重新绑定数据.

 

代码如下:

public void ShowInfoQues()
{
    //定义数据库连接语句:服务器=.(本地) 数据库名=a
    string consqlserver = "Data Source=.;Initial Catalog=a;Integrated Security=True;";
    string sql = "select * from Question";        //定义SQL查询语句
    DataSet ds = new DataSet();                   //定义数据内存中缓存
    SqlConnection con;                            //定义SQL Server连接对象
    SqlDataAdapter da;                            //数据库命令和数据库连接
    con = new SqlConnection(consqlserver);        //定义SQL Server连接对象
    da = new SqlDataAdapter(sql, con);            //数据库命令和数据库连接
    con.Open();
    try
    {
        da.Fill(ds);                                    //填充数据
        dataGridView1.DataSource = ds.Tables[0];        //获取数据源赋值数据库控件
    }
    catch (Exception msg)
    {
        MessageBox.Show(msg.Message);                   //异常处理
    }
    finally
    {
        con.Close();                    //关闭连接
        con.Dispose();                  //释放连接
        da.Dispose();                   //释放资源
    }
}

点击按钮"故障信息删除"后调用该函数ShowInfoQues()即可实现,通常填充数据中需要判断语句如下,如果插入到的结果存在时数据显示在dataGridView控件中,但这样会存在一个问题,当数据库中只存在一个数据时,删除该数据后表中为空就不会更新dataGridView,因为此时已经没有数据就不会执行dataGridView1.DataSource
= ds.Tables[0].它会始终显示一行数据,除非在此载入该窗体,所以此时不需要下面判断:

if (ds.Tables[0].Rows.Count > 0)         //判断是否符合条件的数据记录
{
    dataGridView1.DataSource = ds.Tables[0];
}

在上面代码函数ShowInfoQues()中我设置为public,因为在点击“故障信息导入”按钮,它会进入另外一个界面,在那个界面填写完要插入的数据后同时更新父窗口dataGridView控件中的数据,实现插入数据更新,其中子窗口中的构造函数将带参数,如下图所示是子界面的代码:

//父窗体custServ 父窗体中含函数ShowInfoQues()
custServ cstemp = new custServ();
public custServInput(custServ cs)
{
    InitializeComponent();
    cstemp = cs;
}
//点击"确认添加"按钮实现满意度调查
private void button1_Click(object sender, EventArgs e)
{
    ...                        //插入数据操作
    cstemp.ShowInfoQues();     //父窗口刷新
    this.Hide();               //隐藏窗体
}

父窗体中的代码如下:

//点击"故障信息录入"按钮
private void repInf_Click(object sender, EventArgs e)
{
    custServInput cSI = new custServInput(this);
    cSI.Show();
}

二.数据库主外键的判断

在对数据库进行操作时,通常会遇到判断主键是否存在或是否重复的问题,或判断外键是否存在的问题,因为如果外键不存在是不能插入数据的.在判断主键与外键时,我们可以定义一个函数,通过调用这个函数进行判断.

//该函数用于判断表中Phoneid(手机序列号)是否存在
private bool IsPhoneIdentify()
{
    string consqlserver = "Data Source=.;Initial Catalog=TeleMS;Integrated Security=True;";
    string sql = "select * from Question where phoneid='" + textBox2.Text.Trim() + "'";
    SqlConnection Conn = new SqlConnection(consqlserver);   //定义SQL Server连接对象
    Conn.Open();
    SqlCommand Cmd = new SqlCommand(sql, Conn);
    SqlDataReader reader = Cmd.ExecuteReader();             //数据库命令和数据库连接
    if (reader.Read())                                      //存在
    {
        return true;
    }
    else
    {
        return false;
    }
}

上面代码是判断手机序列号是否存在,它通过判断数据库中phoneid=textBox2内容,如果存在返回true,如果不存在返回false并提示错误信息"该外键不存在,请验证插入!"提示:使用try{..}catch(Exception msg){MessageBox.Show(msg.Message);}finally{..}时C#会自动生成异常信息,但通过自定义函数总体感觉更好,至少让我们能更好的了解数据库原理及常见的操作错误.

三.推荐格式源代码

 通过上面的叙述,可能你还不知道怎样使用这些函数在对数据库进行操作时进行一些简单的判断,下面通过需要插入如图数据,其中主外键表明:

我推荐的代码如下:

//点击"确认记录"按钮实现满意度调查
private void button1_Click(object sender, EventArgs e)
{
    if (textBox1.Text == "" || textBox2.Text == "" || textBox3.Text == "")
    {
        MessageBox.Show("请输入顾客身份证号、售后人员编号和手机序列号!", "信息提示",
                System.Windows.Forms.MessageBoxButtons.OK,
                System.Windows.Forms.MessageBoxIcon.Warning);
    }
    else if (IsCusIdentify() == false)   //顾客身份证号重复(主键)
    {
        MessageBox.Show("该顾客身份证号已经存在,请验证输入!", "错误提示",
            System.Windows.Forms.MessageBoxButtons.OK,
            System.Windows.Forms.MessageBoxIcon.Warning);
    }
    else if (IsPhoneIdentify() == false)  //手机序列号不存在(外键)
    {
        MessageBox.Show("该手机序列号不存在,请验证输入!", "错误提示",
            System.Windows.Forms.MessageBoxButtons.OK,
            System.Windows.Forms.MessageBoxIcon.Warning);
    }
    else if (IsUserIdentify() == false)   //售后人员编号不存在(外键)
    {
        MessageBox.Show("该售后人员编号错误,请验证!", "错误提示",
            System.Windows.Forms.MessageBoxButtons.OK,
            System.Windows.Forms.MessageBoxIcon.Warning);
    }
    else if (MessageBox.Show("确认要添加该进货订单信息?", "验证提示",
        System.Windows.Forms.MessageBoxButtons.YesNo,
        System.Windows.Forms.MessageBoxIcon.Question)==System.Windows.Forms.DialogResult.Yes)
    {
        //实现插入数据操作
        string sqlInsert = string.Format(@"insert into ServiceInfo...");
        string consqlserver = "Data Source=.;Initial Catalog=a;Integrated Security=True;";
        SqlConnection cons = new SqlConnection(consqlserver);   //定义SQL Server连接对象
        SqlCommand cmd = new SqlCommand(sqlInsert, cons);       //执行一个SQL语句
        try
        {
            cons.Open();                                        //打开连接
            cmd.ExecuteNonQuery();                              //返回执行SQL语句的行数
            MessageBox.Show("顾客手机使用满意情况调查数据记录成功!", "信息提示",
                System.Windows.Forms.MessageBoxButtons.OK,
                System.Windows.Forms.MessageBoxIcon.Information);
            csrmtemp.ShowInfoQues();                            //父窗口刷新
            this.Hide();                                        //隐藏窗体
        }
        catch (Exception msg)
        {
            MessageBox.Show(msg.Message);                       //异常处理
        }
        finally
        {
            cons.Close();                                       //关闭连接
            cons.Dispose();                                     //释放连接
            cmd.Dispose();                                      //释放资源
        }
    }
}

四.总结

上面的排版可能有点乱,可能写得不是很好!但作者尽力了.原本想分成两篇写的,但因为上面叙述的几点是最近做项目同时遇到的一些知识,所以就同时写了.主要从dataGridView和主外键两个方面叙述,通过自己认为比较好的代码,传递给大家一些东西.希望大家能学到有用的知识,作者已尽力,如果有不足和不喜欢的地方,见谅!

(By:Eastmount 2013-9-8 夜11点http://blog.csdn.net/eastmount)

时间: 2025-01-02 14:12:18

C# 数据库dataGridView刷新数据和主外键判断的相关文章

城市,区县,地址,没有主外键区分,没有父级ID,所以数据在一个表如何实现级联查询?

问题描述 城市,区县,地址,没有主外键区分,没有父级ID,所以数据在一个表如何实现级联查询? 城市,区县,地址,没有主外键区分,没有父级ID,所以数据在一个表如何实现级联查询? 解决方案 一般这样的情况都是三张表.如果你要放在一张表里面,那么你肯定会有一个父级ID的呀.不然怎么区分,怎么级联? 解决方案二: 都在一个表,我也很纳闷,接手的项目数据库是这样,表示压力好大 解决方案三: 一般不是全在一张表,用level和parentId来区分关联:就是三张表,parentId关联. 没有parent

数据库该如何设计 主外键应该怎么建

问题描述 数据库该如何设计 主外键应该怎么建 现在想做一个类似糗事百科的网站 数据库不知道怎么弄 求大神帮忙! 解决方案 简单来说,主键就是在1对多关系中1的那个,外键就是多的那个.比如两个表:User表有id,Topic表有userid,那么前者是主键,后者是外键. 解决方案二: 其实要做得简单的话,直接几个表就OK了 一个糗事记录表 ID 内容 一个糗事详细记录表 ID 内容 分类(热门.精华.....) 其他一些需要加的内容 踩还是赞 一个评论表 ID 楼层 评论内容 图片路径 踩还是赞

datagridview-关于Winfrom datagridView 刷新数据

问题描述 关于Winfrom datagridView 刷新数据 首先,我这个窗体已经使用了一个自定义的timer了,但是我里面还有两个选项卡, 每个选项卡又有一个DataGridView,而且都要实时更新数据,我测试了加上timer 去对两个选项卡里面的datagridview 进行刷新,会卡死(假死),我绑定的数据是查出来一个dataTable, 然后直接用DataSource= ..来帮顶,求高手支支招哇!!! 解决方案 数据量大,绑定datasource当然会卡死.首先,你不应该轮询.其

Hibernate中主外键的插入问题

问题描述 有两张表,一张userinfo表,一张good表.其中good表中Saler_id列与userinfo表中主键列User_id是主外键的关系.其中在Hibernate的映射文件中的代码如下<many-to-onename="userinfoBySalerId"class="org.epai.web.entity.Userinfo"fetch="select"><columnname="Saler_id&quo

在PowerDesigner中设计物理模型1——表和主外键

原文:在PowerDesigner中设计物理模型1--表和主外键 在PD中建立物理模型由以下几种办法: 直接新建物理模型. 设计好概念模型,然后由概念模型生成物理模型. 设计好逻辑模型,然后由逻辑模型生成物理模型. 使用逆向工程的方法,连接到现有的数据库,由数据库生成物理模型. 物理模型能够直观的反应出当前数据库的结构.在数据库中的表.视图.存储过程等数据库对象都可以在物理模型中进行设计.由于物理模型和数据库的一致性,接下来以数据库对象和物理模型对象的对应来一一介绍: 表 新建物理模型时需要指定

mysql-怎么用程序保证表之间的关联,而不是主外键?

问题描述 怎么用程序保证表之间的关联,而不是主外键? 今天看到这个问题有点疑惑:网上说为了保证数据操作及维护,不建立任何外键,用程序保证关联关系,不建立任何外键关系我明白了,但不知道怎么用程序保证关联关系,,这句话是什么场景,又怎么保证联表查询那??? 解决方案 因为表之间有外检关系的话,数据的读写都会有相对程度的性能影响. 程序来保证起关联就是,增加的时候一起增加,删除的时候一起删除,所有的关联逻辑用程序来管理就可以了.

探讨SQL利用INFORMATION_SCHEMA系统视图如何获取表的主外键信息_Mysql

接着上篇文章<解析SQL 表结构信息查询 含主外键.自增长>里面提到了INFORMATION_SCHEMA视图,其实到了SQL 2005微软都主推大家使用INFORMATION_SCHEMA系统视图,而不是在使用sys东东了,当然目前还是有许多信息只能通过sys视图来查询.这里我们还是以查询表结果信息为例来说明一些主要的INFORMATION_SCHEMA视图的使用.首先我们需要查询列的信息,这需要用到[INFORMATION_SCHEMA].[COLUMNS]系统视图来查询数据列的信息,SQ

[20160719]主外键与延迟约束2.txt

[20160719]主外键与延迟约束2.txt --前几天遇到的问题,因为开发没有在2个存在主外键上的表上建立约束,导致主表记录删除了,而外表数据还在. --主要开发有需求要删除主表的记录,由于条件写错,导致以上情况出现.实际上oracle支持延迟约束,只有提交的时候才会检查. --自己通过例子说明: 1.环境: SCOTT@book> @ &r/ver1 PORT_STRING                    VERSION        BANNER ---------------

[20160716]主外键与延迟约束.txt

[20160716]主外键与延迟约束.txt --前几天遇到的问题,因为开发没有在2个存在主外键上的表上建立约束,导致主表记录删除了,而外表数据还在. --主要开发有需求要删除主表的记录,由于条件写错,导致以上情况出现.实际上oracle支持延迟约束,只有提交的时候才会检查. --自己通过例子说明: 1.环境: SCOTT@test01p> @ ver1 PORT_STRING           VERSION    BANNER