• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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

        }
    }
}

 

 

例:在表中增加行

 

using System.Data.SqlClient;

namespace AddingData
{
    
public partial class Form1 : Form
    {
        
public Form1()
        {
            InitializeComponent();
            btnAdd.Click 
+= new EventHandler(btnAdd_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,companyName from customers";
            
//建立Adapter
            sdaAdapter = new SqlDataAdapter(scCommand);

            
//该对象负责生成用于更新数据库的SQL语句,不必自己创建这些语句
            scbBuilder = new SqlCommandBuilder(sdaAdapter);

            
//得到数据
            sdaAdapter.Fill(dsSet, "customers");
            dgvView.DataSource 
= dsSet.Tables["customers"];
        }

        
void btnAdd_Click(object sender, EventArgs e)
        {
            AddRow();
        }
        
private void AddRow()
        {
            
//新建表中的行
            DataRow drRow = dsSet.Tables["customers"].NewRow();
            drRow[
"customerID"= "ZaCzi";
            drRow[
"companyName"= "Zachary Zithers Ltd.";
            
//增加行
            dsSet.Tables["customers"].Rows.Add(drRow);

            
//更新表
            sdaAdapter.Update(dsSet, "customers");
            
            
//显示
            dgvView.DataSource = dsSet.Tables["customers"];
        }
    }
}

 



鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
在C#中控制ListBox某一行的字体颜色发布时间:2022-07-10
下一篇:
C#查农历阴历阳历公历节假日发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap