C# 事务的创建,提交和回滚

在C#中开启事务的步骤

01.调用SqlConnection对象的BeginTransaction()方法,创建一个SqlTransaction对象,标志事务开始。

02.将创建的SqlTransaction对象分配给要执行的SqlCommand的Transaction属性。

03.调用相应的方法执行SqlCommand命令。

04.调用SqlTransaction的Commit()方法完成事务。或调用Rollback()方法终止事务。  

4.在进行事务操作中的注意点

01.在调用BeginTransaction()方法开始事务之前,要打开数据库连接,否则出现异常。

02.如果在事务的Commit()方法或RollBack()方法执行前数据库连接断开或关闭,则事务将回滚。

            
//准备连接字符串 string str = "data source=.;initial catalog=Myschool;uid=sa;pwd=123"; //创建数据库连接对象 SqlConnection con = new SqlConnection(str); //sql语句:添加一条记录到年级表 string sql = "insert into grade values(@gradename)"; //创建SqlParameter对象,设置参数 SqlParameter sp = new SqlParameter("@gradename", txtgradename.Text); //创建命令对象 SqlCommand cmd = new SqlCommand(sql, con); //通过Parameter集合的add()方法天填充参数集合 cmd.Parameters.Add(sp); //打开连接 con.Open(); //默认让SqlTransaction对象为空 SqlTransaction trans = null; //开启事务:标志事务的开始 trans = con.BeginTransaction(); try { //将创建的SqlTransaction对象分配给要执行的sqlCommand的Transaction属性 cmd.Transaction = trans; //执行sql如果添加成功放回1 int count=cmd.ExecuteNonQuery(); if (count > 0) { MessageBox.Show("成功"); //事务提交 trans.Commit(); } else { MessageBox.Show("失败"); //事务回滚 trans.Rollback(); } } catch (Exception) { //如果某个环节出现问题,则将整个事务回滚 trans.Rollback(); }
posted @   锦大大的博客呀!  阅读(1036)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示