想用Sqlcommandbuilt来更新数据库,更新的数据来自DataGridView里面的数据,求帮忙,谢谢。

解决方案 »

  1.   

    http://www.tzwhx.com/newOperate/html/1/12/121/19650.html看看这个例子。
      

  2.   

    //更新操作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"];        }
        }
    }
      

  3.   

    我要的是更新多张表,好像SqlcommandBuilt没用啊。怎么办啊?