Go homepage(回首页) Upload pictures (上传图片) Write articles (发文字帖)
The author:(作者)归海一刀published in(发表于) 2014/1/30 1:02:32 LINQ体验(10)——LINQ,to,SQL语句之开放式并发控制和事务_[Asp.Net教程]
告诉大家一个好消息:微软于2月1日发布了Visual Studio Team System 2008 Team Suite简体中文版,您可以在这里下载Visual Studio Team System 2008 Team Suite简体中文版90 天试用版。今天简单的学习下开放式并发控制和事务的内容,具体详细的内容现在可以参看MSDN了。
下表介绍 LINQ to SQL 文档中涉及开放式并发的术语:
在 LINQ to SQL 对象模型中,当以下两个条件都得到满足时,就会发生“开放式并发冲突”:客户端尝试向数据库提交更改;数据库中的一个或多个更新检查值自客户端上次读取它们以来已得到更新。 此冲突的解决过程包括查明对象的哪些成员发生冲突,然后决定您希望如何进行处理。
说明:这个例子中在你读取数据之前,另外一个用户已经修改并提交更新了这个数据,所以不会出现冲突。
//我们打开一个新的连接来模拟另外一个用户NorthwindDataContext otherUser_db = new NorthwindDataContext() { Log = db.Log };var otherUser_product = otherUser_db.Products.First(p => p.ProductID == 1);otherUser_product.UnitPrice = 999.99M;otherUser_db.SubmitChanges();//我们当前连接var product = db.Products.First(p => p.ProductID == 1);product.UnitPrice = 777.77M;try {db.SubmitChanges();//当前连接执行成功}catch (ChangeConflictException) {}
说明:我们读取数据之后,另外一个用户获取并提交更新了这个数据,这时,我们更新这个数据时,引起了一个并发冲突。系统发生回滚,允许你找回最近更新的数据,让你决定继续你的更新。
//当前用户var product = db.Products.First(p => p.ProductID == 1);//我们打开一个新的连接来模拟另外一个用户NorthwindDataContext otherUser_db = new NorthwindDataContext() { Log = db.Log };var otherUser_product = otherUser_db.Products.First(p => p.ProductID == 1);otherUser_product.UnitPrice = 999.99M;otherUser_db.SubmitChanges();//当前用户修改product.UnitPrice = 777.77M;try {db.SubmitChanges();}catch (ChangeConflictException) {//发生异常!}
LINQ to SQL 支持三种事务模型,分别是:
说明:这个例子在执行SubmitChanges()操作时,隐式地使用了事务。因为在更新2种产品的库存数量时,第二个产品库存数量为负数了。这导致了更新产品全部失败了,系统回滚到这个操作的初始状态。
try {Product prod1 = db.Products.First(p => p.ProductID == 4);Product prod2 = db.Products.First(p => p.ProductID == 5);prod1.UnitsInStock -= 3;prod2.UnitsInStock -= 5;//错误:库存数量的单位不能是负数//要么全部成功要么全部失败db.SubmitChanges();}catch (System.Data.SqlClient.SqlException e) {//执行异常处理}
说明:这个例子使用事务封闭数据提交。
using (TransactionScope ts = new TransactionScope()) {try {Product prod1 = db.Products.First(p => p.ProductID == 4);Product prod2 = db.Products.First(p => p.ProductID == 5);prod1.UnitsInStock -= 3;prod2.UnitsInStock -= 5;//错误:库存数量的单位不能是负数db.SubmitChanges();}catch (System.Data.SqlClient.SqlException e) {//执行异常处理}}
作者:李永京(YJingLee's Blog)出处:http://lyj.cnblogs.com
赞