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


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


此处将资料从数据库得出后显在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"];         }    }}

  

智能推荐

注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
© 2014-2019 ITdaan.com 粤ICP备14056181号  

赞助商广告