C#使用SqlDataAdapter.Update更新数据库

来源:互联网 发布:英国高中帅哥知乎 编辑:程序博客网 时间:2024/05/21 08:03

http://www.cnblogs.com/ChangTan/archive/2011/12/27/2303901.html


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

    资料显示方法不用多说。

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

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

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

 

    例:更新表中内容:

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

  

原创粉丝点击