<>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"];



        }

    }

}

  

你可能感兴趣的:(Adapter)