分享
 
 
 

使用 Visual C# .NET 从数据集对象更新数据库

王朝c#·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

适用于

本文的发布号曾为 CHS307587

有关本文的 Microsoft Visual Basic .NET 版本,请参见 301248

本任务的内容

概要

要求

如何从数据集对象更新数据库

完整代码列表

参考

概要数据集对象是 Microsoft .NET 框架中数据访问的关键部分,是可保存表、视图和关系的内存中对象。本文介绍了如何获取包含数据(从数据库加载)的数据集、如何修改此数据,以及接着如何再将其发回数据库以更新原始数据源。

返回页首

要求下表概括了推荐使用的硬件、软件、网络结构以及所需的服务包:

Microsoft Windows 2000 Professional、Microsoft Windows 2000 Server、Microsoft Windows 2000 Advanced Server 或 Microsoft Windows NT 4.0 Server

Microsoft SQL Server 7.0 版、Microsoft SQL Server 2000 或安装了 PUBS 示例数据库的 Microsoft Data Engine (MSDE)

Microsoft Visual Studio .NET本文假定您熟悉以下主题:

数据库技术

结构化查询语言 (SQL) 返回页首

如何从数据集对象更新数据库本节演示如何使用数据集对象更新数据库中的数据。还可以使用 SqlCommand 对象直接在数据库中插入、更新和删除数据,记住这一点很重要。

如想更好地理解本文,请单击下面的文章编号以查看 Microsoft 知识库中的文章:

314145 HOW TO: Populate a DataSet Object from a Database by Using Visual C# .NET(使用 Visual C# .NET 从数据库填充数据集对象)314145 一文中讲述了如何从数据库检索数据和将此数据传送到数据集中,并讲述了为什么数据集独立于数据库以及它与数据库有何区别。

加载数据集后,就可以修改数据了。 数据集将跟踪这些更改。 可将数据集对象视为从数据库检索出的缓存于内存中的数据。 数据集对象由一个包含表、关系和约束的集合构成。

若要更新数据集并将这些更新发回数据库,请按照下列步骤操作:

打开 Microsoft Visual Studio .NET。

在 Visual C# .NET 中新建一个控制台应用程序。 Visual Studio 在默认情况下将创建一个静态类和一个空的 Main() 过程。

确保该项目包含对 System 和 System.Data 命名空间的引用。对 System、SystemData 和 System.Data.SqlClient 命名空间使用 using 语句,这样,在后面的代码中就不需要限定这些命名空间中的声明了。必须在任何其他声明之前使用这些语句。 using System;

using System.Data;

using System.Data.SqlClient;

在修改数据并将更改发回数据库之前,必须将该信息加载到 DataSet (数据集)中。 有关详细过程,请参见314145。为避免重复,将不详细提供该步骤中的代码。

以下代码中的连接字符串指向其“sa”帐户具有空密码的本地计算机(或运行这段代码的计算机)上的 SQL Server。如果需要的话,请用您自己的设置替换该字符串。总之,先创建连接,然后创建数据适配器;该适配器用于将数据填充到 DataSet 中。 string sConnectionString;

// Modify the following string to correctly connect to your SQL Server.

sConnectionString = "Password=;User ID=sa;"

+ "Initial Catalog=pubs;"

+ "Data Source=(local)";

SqlConnection objConn

= new SqlConnection(sConnectionString);

objConn.Open();

// Create an instance of a DataAdapter.

SqlDataAdapter daAuthors

= new SqlDataAdapter("Select * From Authors", objConn);

// Create an instance of a DataSet, and retrieve data from the Authors table.

DataSet dsPubs = new DataSet("Pubs");

daAuthors.FillSchema(dsPubs,SchemaType.Source, "Authors");

daAuthors.Fill(dsPubs,"Authors");

现在已经加载了数据,您可以对其进行修改。添加行(或记录)有多种方法。该代码示例使用一个三步式过程:

从 DataTable 获取一个新的 DataRow 对象。

根据需要设置 DataRow 字段的值。

将新对象传递到 DataTable.Rows 集合的 Add 方法中。

将以下代码粘贴到第 4 步中的代码的后面: //****************

// BEGIN ADD CODE

// Create a new instance of a DataTable.

DataTable tblAuthors;

tblAuthors = dsPubs.Tables["Authors"];

DataRow drCurrent;

// Obtain a new DataRow object from the DataTable.

drCurrent = tblAuthors.NewRow();

// Set the DataRow field values as necessary.

drCurrent["au_id"] = "993-21-3427";

drCurrent["au_fname"] = "George";

drCurrent["au_lname"] = "Johnson";

drCurrent["phone"] = "800 226-0752";

drCurrent["address"] = "1956 Arlington Pl.";

drCurrent["city"] = "Winnipeg";

drCurrent["state"] = "MB";

drCurrent["contract"] = 1;

// Pass that new object into the Add method of the DataTable.

tblAuthors.Rows.Add(drCurrent);

Console.WriteLine("Add was successful, Click any key to continue!!");

Console.ReadLine();

// END ADD CODE

将以下代码粘贴到第 4 步中的代码的后面:若要编辑现有行,请获取相应的 DataRow 对象,然后为一列或多列提供新值。必须先找到正确的行,由于您加载了表的架构和数据(在第 4 步中对 FillSchema 的调用),因此这一过程非常简单。有了架构,表就知道哪个列是它的主键,同时 Rows 集合的 Find 方法也就可用了。

Find 方法将返回 DataRow 对象,此对象的主键(在本例中为 au_id)已有了一个具体的值。有了该 DataRow 之后,您就可以修改列了。您无需包装 BeginEdit 和 EndEdit 中的修改,但进行包装可简化 DataSet 必须完成的工作,并且使 DataSet 可以在调用 EndEdit 的同时执行它的验证检查。将以下代码粘贴到 ADD 代码之后: //*****************

// BEGIN EDIT CODE

drCurrent = tblAuthors.Rows.Find("213-46-8915");

drCurrent.BeginEdit();

drCurrent["phone"] = "342" + drCurrent["phone"].ToString().Substring(3);

drCurrent.EndEdit();

Console.WriteLine("Record edited successfully, Click any key to continue!!");

Console.ReadLine();

// END EDIT CODE

将以下代码粘贴到第 4 步中的代码的后面:若要用所有这些更改更新原数据库,请将 DataSet 传递到 DataAdapter 对象的 Update 方法中。

但是,在您调用 Update 前,必须设置 DataAdapter 对象的 InsertCommand、UpdateCommand 和 DeleteCommand 属性。可手动编写 SQL 并用相应的 SqlCommand 对象填充这三个属性,但也可以使用 Visual Studio .NET 自动生成这三个命令。

若要在需要时生成所需的命令,必须创建 SqlCommandBuilder 对象的实例并在构造函数中使用 DataAdapter。如果想使用此方法(在以下代码示例中阐释),您的表必须有主键信息。若要访问主键信息,请调用 FillSchema,然后将 DataAdapter 的 MissingSchemaAction 属性设置为 AddWithKey,或在代码中手动设置主键。将以下代码粘贴到 EDIT 代码之后: //*****************

// BEGIN SEND CHANGES TO SQL SERVER

SqlCommandBuilder objCommandBuilder = new SqlCommandBuilder(daAuthors);

daAuthors.Update(dsPubs, "Authors");

Console.WriteLine("SQL Server updated successfully, Check Server explorer to see changes");

Console.ReadLine();

// END SEND CHANGES TO SQL SERVER

将以下代码粘贴到第 4 步中的代码的后面:若要完全删除某一行,请使用 DataRow 对象的 Delete 方法。请注意,Rows 集合包含 Remove 和 RemoveAt 两个方法,它们似乎可以删除行,而实际上只是从集合中移除行。只有 Delete 方法才会将删除结果发回源数据库中。将以下代码粘贴到 SEND CHANGES TO SQL SERVER 代码之后: //*****************

//BEGIN DELETE CODE

drCurrent = tblAuthors.Rows.Find("993-21-3427");

drCurrent.Delete();

Console.WriteLine("Record deleted successfully, Click any key to continue!!");

Console.ReadLine();

//END DELETE CODE

将以下代码粘贴到第 4 步中的代码的后面:将这些更改发送到 SQL Server 以移除早先添加的记录。将以下代码粘贴到 DELETE 代码之后: //*****************

// CLEAN UP SQL SERVER

daAuthors.Update(dsPubs, "Authors");

Console.WriteLine("SQL Server updated successfully, Check Server explorer to see changes");

Console.ReadLine();

将以下代码粘贴到第 4 步中的代码的后面:保存项目。

将以下代码粘贴到第 4 步中的代码的后面:在调试菜单上,单击开始以运行该项目。请注意,将出现几个消息框,它们指示代码的执行进度并让您能够在执行过程中查看数据的当前状态。 返回页首

完整代码列表 using System;

using System.Data;

using System.Data.SqlClient;

namespace PopulateDataSet

{

/// <summary>

/// Summary description for Class1.

/// </summary>

class Class1

{

static void Main(string[] args)

{

string sConnectionString;

// Modify the following string to correctly connect to your SQL Server.

sConnectionString = "Password=;User ID=sa;"

+ "Initial Catalog=pubs;"

+ "Data Source=(local)";

SqlConnection objConn

= new SqlConnection(sConnectionString);

objConn.Open();

// Create an instance of a DataAdapter.

SqlDataAdapter daAuthors

= new SqlDataAdapter("Select * From Authors", objConn);

// Create an instance of a DataSet, and retrieve

// data from the Authors table.

DataSet dsPubs = new DataSet("Pubs");

daAuthors.FillSchema(dsPubs,SchemaType.Source, "Authors");

daAuthors.Fill(dsPubs,"Authors");

//****************

// BEGIN ADD CODE

// Create a new instance of a DataTable.

DataTable tblAuthors;

tblAuthors = dsPubs.Tables["Authors"];

DataRow drCurrent;

// Obtain a new DataRow object from the DataTable.

drCurrent = tblAuthors.NewRow();

// Set the DataRow field values as necessary.

drCurrent["au_id"] = "993-21-3427";

drCurrent["au_fname"] = "George";

drCurrent["au_lname"] = "Johnson";

drCurrent["phone"] = "800 226-0752";

drCurrent["address"] = "1956 Arlington Pl.";

drCurrent["city"] = "Winnipeg";

drCurrent["state"] = "MB";

drCurrent["contract"] = 1;

// Pass that new object into the Add method of the DataTable.

tblAuthors.Rows.Add(drCurrent);

Console.WriteLine("Add was successful, Click any key to continue!!");

Console.ReadLine();

// END ADD CODE

//*****************

// BEGIN EDIT CODE

drCurrent = tblAuthors.Rows.Find("213-46-8915");

drCurrent.BeginEdit();

drCurrent["phone"] = "342" + drCurrent["phone"].ToString().Substring(3);

drCurrent.EndEdit();

Console.WriteLine("Record edited successfully, Click any key to continue!!");

Console.ReadLine();

// END EDIT CODE

//*****************

// BEGIN SEND CHANGES TO SQL SERVER

SqlCommandBuilder objCommandBuilder = new SqlCommandBuilder(daAuthors);

daAuthors.Update(dsPubs, "Authors");

Console.WriteLine("SQL Server updated successfully, Check Server explorer to see changes");

Console.ReadLine();

// END SEND CHANGES TO SQL SERVER

//*****************

//BEGIN DELETE CODE

drCurrent = tblAuthors.Rows.Find("993-21-3427");

drCurrent.Delete();

Console.WriteLine("SRecord deleted successfully, Click any key to continue!!");

Console.ReadLine();

//END DELETE CODE

//*****************

// CLEAN UP SQL SERVER

daAuthors.Update(dsPubs, "Authors");

Console.WriteLine("SQL Server updated successfully, Check Server explorer to see changes");

Console.ReadLine();

}

}

}

返回页首

参考有关使用 ADO.NET、数据集对象和 SQL 的更多信息,请访问以下 Microsoft Web 站点:

深入了解数据访问(MSDN 之音专栏)

http://msdn.microsoft.com/voices/data.asp

ADO.NET 与 ADO 编程人员

http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dndotnet/html/adonetprogmsdn.asp

MSDN Online .NET 开发人员中心

http://msdn.microsoft.com/net

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有