演练:操作数据 (Visual Basic)
本演练提供了用于在数据库中添加、修改和删除数据的基本端对端 LINQ to SQL 方案。 您将使用 Northwind 示例数据库的一个副本来添加一位客户,更改该客户的姓名,然后删除一个订单。
注意
以下说明中的某些 Visual Studio 用户界面元素在计算机上出现的名称或位置可能会不同。 这些元素取决于你所使用的 Visual Studio 版本和你所使用的设置。 有关详细信息,请参阅个性化设置 IDE。
本演练是使用 Visual Basic 开发设置编写的。
先决条件
本演练需要如下内容:
本演练使用专用文件夹(“c:\linqtest2”)来保存文件。 请在开始本演练前创建此文件夹。
Northwind 示例数据库。
如果您的开发计算机上没有此数据库,您可以从 Microsoft 下载网站下载它。 有关说明,请参阅下载示例数据库。 下载此数据库后,请将 northwnd.mdf 文件复制到 c:\linqtest2 文件夹。
从 Northwind 数据库生成的 Visual Basic 代码文件。
可以使用对象关系设计器或 SQLMetal 工具生成此文件。 本演练是通过使用 SQLMetal 工具以及如下命令行编写的:
sqlmetal /code:"c:\linqtest2\northwind.vb" /language:vb "C:\linqtest2\northwnd.mdf" /pluralize
有关详细信息,请参阅 SqlMetal.exe(代码生成工具)。
概述
本演练由六项主要任务组成:
在 Visual Studio 中创建 LINQ to SQL 解决方案。
向项目添加数据库代码文件。
创建新的客户对象。
修改客户的联系人姓名。
删除订单。
将这些更改提交至 Northwind 数据库。
创建 LINQ to SQL 解决方案
在这第一项任务中,你将创建一个 Visual Studio 解决方案,其中包含生成和运行 LINQ to SQL 项目所必需的引用。
创建 LINQ to SQL 解决方案
在 Visual Studio“文件”菜单上,单击“新建项目”。
在“新建项目”对话框的“项目类型”窗格中,单击“Visual Basic”。
在“模板”窗格中,单击“控制台应用程序”。
在“名称”框中,键入“LinqDataManipulationApp”。
单击“确定”。
添加 LINQ 引用和指令
本演练用到默认情况下您的项目中可能未安装的程序集。 如果在你的项目中未将 System.Data.Linq
作为引用列出(在“解决方案资源管理器”中单击“显示所有文件”并展开“引用”节点),请按照以下步骤中的说明添加。
添加 System.Data.Linq
在解决方案资源管理器中,右键单击“引用”,然后单击“添加引用”。
在“添加引用”对话框中,依次单击“.NET”、System.Data.Linq 程序集,再单击“确定”。
此程序集即被添加到项目中。
在代码编辑器中,在“Module1”上面添加以下指令:
Imports System.Data.Linq Imports System.Data.Linq.Mapping
将 Northwind 代码文件添加到项目
以下这些步骤假定你已使用 SQLMetal 工具从 Northwind 示例数据库生成代码文件。 有关更多信息,请参见本演练前面部分的“先决条件”一节。
将 northwind 代码文件添加到项目
在“项目”菜单上,单击“添加现有项”。
在“添加现有项”对话框中,导航到 c:\linqtest2\northwind.vb,然后单击“添加”。
northwind.vb 文件即被添加到项目中。
设置数据库连接
首先,测试与数据库的连接。 特别要注意,数据库的名称 Northwnd 不含 i 字符。 如果在后面的步骤中产生错误,请检查 northwind.vb 文件以确定 Northwind 分部类的拼写是否正确。
设置并测试数据库连接
将下面的代码键入或粘贴到
Sub Main
中:' Use a connection string, but connect to ' the temporary copy of the database. Dim db As New Northwnd _ ("C:\linqtest2\northwnd.mdf") ' Keep the console window open after activity stops. Console.ReadLine()
按 F5 在此点测试应用程序。
“控制台”窗口即会打开。
通过在“控制台”窗口中按 Enter,或在 Visual Studio 的“调试”菜单上单击“停止调试”来关闭应用程序。
创建新实体
创建新实体很简单。 可以使用 Customer
关键字创建对象(如 New
)。
在本节及后续各节中,您将只对本地缓存进行更改。 如果您不调用 SubmitChanges,则不会向数据库发送任何更改,一直到本演练结束都是如此。
添加新的 Customer 实体对象
通过在
Customer
中的Console.ReadLine
前添加如下代码,创建一个新的Sub Main
:' Create the new Customer object. Dim newCust As New Customer() newCust.CompanyName = "AdventureWorks Cafe" newCust.CustomerID = "A3VCA" ' Add the customer to the Customers table. db.Customers.InsertOnSubmit(newCust) Console.WriteLine("Customers matching CA before insert:") Dim custQuery = _ From cust In db.Customers _ Where cust.CustomerID.Contains("CA") _ Select cust For Each cust In custQuery Console.WriteLine("Customer ID: " & cust.CustomerID) Next
按 F5 调试解决方案。
控制台窗口中显示的结果如下:
Customers matching CA before insert:
Customer ID: CACTU
Customer ID: RICAR
请注意,新行不会出现在结果中, 因为新数据尚未提交到数据库。
在“控制台”窗口中按 Enter,以停止调试。
更新实体
在以下步骤中,您将检索一个 Customer
对象并修改其属性之一。
更改客户的姓名
将下面的代码添加到
Console.ReadLine()
上方:Dim existingCust = _ (From cust In db.Customers _ Where cust.CustomerID = "ALFKI" _ Select cust).First() ' Change the contact name of the customer. existingCust.ContactName = "New Contact"
删除实体
使用同一客户对象,您可以删除第一个订单。
下面的代码演示如何切断行与行之间的关系,以及如何从数据库中删除行。
删除行
将下面的代码添加到
Console.ReadLine()
上方紧靠它的位置:' Access the first element in the Orders collection. Dim ord0 As Order = existingCust.Orders(0) ' Access the first element in the OrderDetails collection. Dim detail0 As OrderDetail = ord0.OrderDetails(0) ' Display the order to be deleted. Console.WriteLine _ (vbCrLf & "The Order Detail to be deleted is: OrderID = " _ & detail0.OrderID) ' Mark the Order Detail row for deletion from the database. db.OrderDetails.DeleteOnSubmit(detail0)
将更改提交到数据库
创建、更新和删除对象所需执行的最后一步是将真正将更改提交到数据库。 如不执行这一步,您所做的更改将仅限本地,不会出现在查询结果中。
将更改提交到数据库
将下面的代码插入到
Console.ReadLine
上方紧靠它的位置:db.SubmitChanges()
将下面的代码插入到
SubmitChanges
后面,以显示提交更改前后的效果:Console.WriteLine(vbCrLf & "Customers matching CA after update:") Dim finalQuery = _ From cust In db.Customers _ Where cust.CustomerID.Contains("CA") _ Select cust For Each cust In finalQuery Console.WriteLine("Customer ID: " & cust.CustomerID) Next
按 F5 调试解决方案。
控制台窗口显示如下:
Customers matching CA before update: Customer ID: CACTU Customer ID: RICAR The Order Detail to be deleted is: OrderID = 10643 Customers matching CA after update: Customer ID: A3VCA Customer ID: CACTU Customer ID: RICAR
在“控制台”窗口中按 Enter,以停止调试。
备注
通过提交更改添加了新的客户后,您无法再次按原样执行此解决方案,因为您无法再次按原样添加相同的客户。 若要再次执行此解决方案,请更改要添加的客户 ID 值。