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

  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值