zoukankan      html  css  js  c++  java
  • <转载>C#使用SqlDataAdapter.Update更新数据库

     此处将资料从数据库得出后显在DataGridView上显示。然后变更数据。变更数据的方法在按钮事件中。

        资料显示方法不用多说。

        更新时主要用到SqlCommandBuilder类和SqlDataAdapter.Update()方法。

    SqlCommandBuilder对象负责生成用于更新数据库的SQL语句,不必自己创建这些语句。

            UpDate方法自动遍历DataTable中的行,以找出需要对数据库作出变动。Rows集合中每个DataRow对象都具有属性RowState,可以跟踪此行是否已删除、添加、修改,还是未作变动。所作的任何变化都会反映到数据库中。

        例:更新表中内容:

    using System.Data.SqlClient;
    
    namespace UpdatingData
    {
        public partial class Form1 : Form
        {
            public Form1()
            {
                InitializeComponent();
                btnUpdate.Click += new EventHandler(btnUpdate_Click);
                UpdateData();
            }
    
            string sConnection = "Data Source=scott;Initial Catalog=northwind;Persist Security Info=True;User ID=sa;Password=sa123";
            DataSet dsSet = new DataSet();
            SqlDataAdapter sdaAdapter = null;
            SqlCommandBuilder scbBuilder = null;
            private void UpdateData()
            {
                //建立Connection
                SqlConnection scConnection = new SqlConnection(sConnection);
                //建立Command
                SqlCommand scCommand = scConnection.CreateCommand();
                scCommand.CommandText = "select customerID,contactName from customers";
                //建立Adapter
                sdaAdapter = new SqlDataAdapter(scCommand);
    
                //该对象负责生成用于更新数据库的SQL语句,不必自己创建这些语句
                scbBuilder = new SqlCommandBuilder(sdaAdapter);
    
                //得到数据
                sdaAdapter.Fill(dsSet, "customers");
                dgvView.DataSource = dsSet.Tables["customers"];
    
            }
    
            void btnUpdate_Click(object sender, EventArgs e)
            {
                //设置值
                dsSet.Tables["customers"].Rows[3]["contactName"] = "Thomas Hardy";
                //更新数据(UpDate方法自动遍历DataTable中的行,以找出需要对数据库作出变动)
                //Rows集合中每个DataRow对象都具有属性RowState,可以跟踪此行是否已删除、添加、修改,还是未作变动。所作的任何变化都会反映到数据库中。
                sdaAdapter.Update(dsSet, "customers");
                dgvView.DataSource = dsSet.Tables["customers"];
    
            }
        }
    }
    

      

  • 相关阅读:
    019-centos的yum用法
    018-DNS解析过程与配置DNS服务
    017-linux正则表达式
    016-sed
    014-配置SSH免密钥登录
    013-安装VNC服务
    012-centos6.5配置静态ip
    010-centos上安装matlab
    mysqlbinlog
    更换mysql数据库的datadir目录
  • 原文地址:https://www.cnblogs.com/ChangTan/p/2303901.html
Copyright © 2011-2022 走看看