博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# 事务
阅读量:5368 次
发布时间:2019-06-15

本文共 1701 字,大约阅读时间需要 5 分钟。

1、创建事务的结构

SqlConnection   sqlConnection   =   new   SqlConnection();   

  ...初始化连接   
  //   开启事务   
  SqlTransaction   sqlTransaction   =   sqlConnection.BeginTransaction();   
  //   将事务应用于Command   
  SqlCommand   sqlCommand   =   new   SqlCommand();   
  sqlCommand.Connection   =   sqlConnection;   
  sqlCommand.Transaction   =   sqlTransaction;     
  try   
  {   
  //   利用sqlcommand进行数据操作   
  ...   
  //   成功提交   
  sqlTransaction.Commit();   
  }   
  catch(Exception   ex)   
  {   
  //   出错回滚   
  sqlTransaction.Rollback();   
  }  

2、简单例子

                  {   

                          DataTable   dt   =   new   DataTable();   
                          System.Data.SqlClient.SqlConnection   cnn   =   new   System.Data.SqlClient.SqlConnection("连接字符串");   
                          System.Data.SqlClient.SqlCommand   cm   =   new   System.Data.SqlClient.SqlCommand();   
                          cm.Connection   =   cnn;   
                          cnn.Open();   
                          System.Data.SqlClient.SqlTransaction   trans   =   cnn.BeginTransaction();   
                          try   
                          {   
                                  foreach(DataRow   dr   in   dt.Rows)   
                                  {  
                                          cm.CommandText   =   "update   [表]   set   [数量]   =   @amount   where   productID   =   @productID";   
                                          cm.Parameters.Add("@amount",SqlDbType.Int);   
                                          cm.Parameters["@amount"].Value   =   Convert.ToInt32(dr["amount"]);   
                                          cm.Parameters.Add("@productID",SqlDbType.VarChar);   
                                          cm.Parameters["@productID"].Value   =   dr["productID"].ToString();   
                                          cm.ExecuteNonQuery();   
                                  }   
                                  trans.Commit();   
                          }   
                          catch   
                          {   
                                  trans.Rollback();   
                          }   
                          finally   
                          {   
                                  cnn.Close();   
                                  trans.Dispose();   
                                  cnn.Dispose();   
                          }   
                  }

3、SQl server中的事务例子

begin transaction 

save transaction A

insert into demo values('BB','B term')

rollback TRANSACTION A

create table demo2(name varchar(10),age int)

insert into demo2(name,age) values('lis',1)
rollback transaction

  insert into demo values('BB','B term')

 commit TRANSACTION A

 commit TRANSACTION  

4、注意

  1。事务必须在连接打开后BeginTransaction();

  2.事务添加到SqlCommand(sqlCommand.Transaction   =   sqlTransaction;   )

  3、其他数据库对应做相应调整

  4、可以用微软提供的一个dll,很方便.

转载于:https://www.cnblogs.com/litaohao/archive/2013/03/02/2939778.html

你可能感兴趣的文章
牛客多校3 A-PACM Team(状压降维+路径背包)
查看>>
HDU - 4284 Travel(floyd+状压dp)
查看>>
1027 制作表格
查看>>
Android之Socket通信、List加载更多、Spinner下拉列表
查看>>
面向对象的介绍与特性
查看>>
typing-python用于类型注解的库
查看>>
20189215 2018-2019-2 《密码与安全新技术专题》第13周作业
查看>>
第四周作业
查看>>
一、HTML基础
查看>>
蓝牙进阶之路 (002) - HC-05与HC-06的AT指令的区别(转)
查看>>
mysql的limit经典用法及优化
查看>>
C#后台程序与HTML页面中JS方法互调
查看>>
mysql 同一个表中 字段a 的值赋值到字段b
查看>>
linux系统可执行文件添加环境变量使其跨终端和目录执行
查看>>
antiSMASH数据库:微生物次生代谢物合成基因组簇查询和预测
查看>>
UNICODE与ANSI的区别
查看>>
nginx 配置实例
查看>>
Flutter - 创建底部导航栏
查看>>
ASP.NET MVC 教程-MVC简介
查看>>
SQL Server索引 - 聚集索引、非聚集索引、非聚集唯一索引 <第八篇>
查看>>