• <转载>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"];
    
            }
        }
    }
    

      

  • 相关阅读:
    .net通用签名方法 webapi签名方法
    实体类的[Serializable]标签造成WebAPI Post接收不到值
    html5获取位置信息,h5获取位置信息
    C#采集:图灵机器人信息
    virtualbox压缩虚拟机硬盘文件vhd
    WinFrom控件双向绑定
    ILMerge合并多个DLL
    在Windows Server 2012 R2的Hyper-V中设置虚拟机启用增强会话模式
    (转)✈工欲善其事,必先利其器✔™
    .NET使用ZXing.NET生成中间带图片的二维码
  • 原文地址:https://www.cnblogs.com/ChangTan/p/2303901.html
Copyright © 2020-2023  润新知