C#代码启用事务锁Transaction进行一系列提交回滚操作
一、前言
因为很多人一般进行一系列相关数据库操作都是在存储过程里面,而且在存储过程用锁的写法也是很简单的,在这篇文章主要介绍一下C#后台代码用锁进行一系列事务操作,我建立一个简单的winform程序,然后做一个事务:修改指定ID的用户信息,然后新增一名用户信息,操作成功就提交事务,程序异常和数据库执行不成功都必须回滚事务!
二、存储过程的事务
写得比较简单,我想大家都知道怎么使用了,不懂的可以问我。
三、C#代码的事务
1.封装一个事务类,里面有事务的创建、提交事务、回滚事务和销毁事务的方法
public class TransactionDal : SqlHelper
{
public DbConnection dbconnection = null;
public DbTransaction transaction = null;
public void BeginTransaction()
{
dbconnection = SqlHelper.CreateConnection();
dbconnection.Open();
transaction = dbconnection.BeginTransaction();
}
public void CommitTransaction()
{
if (null != transaction)
{
transaction.Commit();
}
}
public void RollbackTransaction()
{
if (null != transaction)
{
transaction.Rollback();
}
}
public void DisposeTransaction()
{
if (dbconnection.State == ConnectionState.Open)
{
dbconnection.Close();
}
if (null != transaction)
{
transaction.Dispose();
}
}
}
2.封装简单的数据层用到事务的方法
public class SqlHelper
{
private static readonly string constr = ConfigurationManager.ConnectionStrings["strCon"].ConnectionString;
/// <summary>
/// 有锁的事务方法
/// </summary>
/// <param name="tran"></param>
/// <param name="sql"></param>
/// <param name="pms"></param>
/// <returns></returns>
public static int ExecuteNonQuery(IDbTransaction tran,string sql, params SqlParameter[] pms)
{
using (SqlCommand cmd = new SqlCommand(sql, (SqlConnection)tran.Connection, (SqlTransaction)tran))
{
if (pms != null)
{
cmd.Parameters.AddRange(pms);
}
return cmd.ExecuteNonQuery();
}
}
public static DataTable ExecuteDataTable(string sql, params SqlParameter[] pms)
{
SqlDataAdapter adapter = new SqlDataAdapter(sql, constr);
if (pms != null)
{
adapter.SelectCommand.Parameters.AddRange(pms);
}
DataTable dt = new DataTable();
adapter.Fill(dt);
return dt;
}
protected static System.Data.Common.DbConnection CreateConnection()
{
SqlConnection con = new SqlConnection(constr);
return con;
}
}
3.winform程序
3.1程序界面
3.2C#代码修改用户信息并新增用户信息用到了事务
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
dataGridView1.DataSource = GetUsersTable();
}
/// <summary>
/// 给dataGridView绑定数据源
/// </summary>
/// <returns></returns>
private DataTable GetUsersTable()
{
string sql = "select * from Users";
DataTable dt = SqlHelper.ExecuteDataTable(sql, null);
return dt;
}
/// <summary>
/// 点击修改并新增按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button_Click(object sender, EventArgs e)
{
string strUserID = txtID.Text.Trim();
string strUserName = txtUserName.Text.Trim();
string strAge = txtAge.Text.Trim();
string strAddress = txtAddress.Text.Trim();
string strNewUserName = txtNewUserName.Text.Trim();
string strNewAge = txtNewAge.Text.Trim();
string strNewAddress = txtNewAddress.Text.Trim();
if (strUserID != "" && strUserName != "" && strAge != "" && strAddress != "" && strNewUserName != "" && strNewAge != "" && strNewAddress != "")
{
int error = UpdateUserMsg(strUserID, strUserName, strAge, strAddress, strNewUserName, strNewAge, strNewAddress);
)
{
dataGridView1.DataSource = GetUsersTable();//重新绑定学生数据源
MessageBox.Show("整个事务操作成功");
}
else
{
MessageBox.Show("整个事务操作失败");
}
}
else
{
MessageBox.Show("请填写完整信息");
}
}
/// <summary>
/// 修改指定学生信息
/// </summary>
/// <returns></returns>
private int UpdateUserMsg(string strUserID, string strUserName, string strAge, string strAddress, string strNewUserName, string strNewAge, string strNewAddress)
{
TransactionDal dalTran = new TransactionDal(); //实例化封装好事务类的TransactionDal
;
try
{
dalTran.BeginTransaction(); //这里开启事务锁
string sql = string.Format("update Users set UserName='{0}',Age={1},Address='{2}' where UserID={3}", strUserName, strAge, strAddress, strUserID);
int mod = SqlHelper.ExecuteNonQuery(dalTran.transaction, sql, null); //传参:事务锁,sql, null ,执行修改操作
)//执行成功
{
int mod2 = AddUser(dalTran.transaction, strNewUserName, strNewAge, strNewAddress);//如果一系列操作是相关的也要传递锁过去
)
{
dalTran.CommitTransaction(); //执行提交
}
else
{ //执行失败回滚
error += ;
dalTran.RollbackTransaction();
}
}
else //执行失败回滚
{
error += ;
dalTran.RollbackTransaction();
return error;
}
}
catch (Exception)
{ //执行异常回滚
error += ;
dalTran.RollbackTransaction();
}
finally
{
dalTran.DisposeTransaction(); //释放锁,释放连接实例
}
return error;
}
//新增学生,在整个事务中也需要传递同个事务事例
private int AddUser(IDbTransaction tran, string strNewUserName, string strNewAge, string strNewAddress)
{
string sql = string.Format("insert into Users values('{0}',{1},'{2}')", strNewUserName, strNewAge, strNewAddress);
int mod = SqlHelper.ExecuteNonQuery(tran, sql, null);
return mod;
}
}
四、总结
C#事务锁要try{}catch{}finally{},在一系列相关操作的时候开启了事务锁就只能在同一个数据库连接实例进行锁的操作, 代码都写得比较简单,大家会用C#代码事务,封装合适自己使用的就好了。
C#代码启用事务锁Transaction进行一系列提交回滚操作的更多相关文章
- EF Core利用Transaction对数据进行回滚保护
What? 首先,说一下什么是EF Core中的Transaction Transaction允许以原子方式处理多个数据库操作,如果事务已提交,则所有操作都应用于数据库,如果事务回滚,则没有任何操作应 ...
- JDBC事务提交/回滚实例
以下是使用事务教程中描述的提交和回滚的代码示例. 此示例代码是基于前面章节中完成的环境和数据库设置编写的. 复制并将以下示例代码保存到:CommitAndRollback.java 中,编译并运行如下 ...
- Spring事务只对运行时异常回滚
我们在使用Spring时候一般都知道事务在遇到异常的时候会回滚,岂不知Spring的事务默认只有在发生运行时异常即:RunTimeException时才会发生事务,如果一个方法抛出Exception或 ...
- Spring学习笔记——Spring事务仅仅对执行时异常回滚
我们在使用Spring时候一般都知道事务在遇到异常的时候会回滚.岂不知Spring的事务默认仅仅有在发生执行时异常即:RunTimeException时才会发生事务,假设一个方法抛出Exception ...
- Android学习笔记_9_SQLiteOpenHelper对象之数据库增删改查以及事务回滚操作
一.SQLite数据库: 在Android平台上,集成了一个嵌入式关系型数据库—SQLite,SQLite3支持 NULL.INTEGER.REAL(浮点数字).TEXT(字符串文本)和BLOB(二进 ...
- SQL的事务回滚操作带案例分析
SET XACT_ABORT on BEGIN TRAN INSERT INTO [PDA_Action] VALUES ('採购入库1') INSERT INTO [PDA_Action] V ...
- [转] C# mysql 事务回滚
什么是数据库事务 数据库事务是指作为单个逻辑工作单元执行的一系列操作. 设想网上购物的一次交易,其付款过程至少包括以下几步数据库操作: · 更新客户所购商品的库存信息 · 保存客户付款信息--可能包括 ...
- spring boot 使用 mybatis 开启事务回滚 的总结
1.前言 以前没有使用mybatis,可以关闭自动提交,然后做sql操作,对操作进行catch捕获异常, 如果没有异常则commit 提交 ,有异常则 rollback 回滚,新增的数据则删除 ,修改 ...
- Oracle 事务 锁
一. 事务 是一系列的数据库操作,是数据库应用的基本逻辑单位以及并发控制的基本单位.所谓的事务,它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位. 要将有组语句作为事务考 ...
随机推荐
- Unable to open log device '/dev/log/main': No such file or directory
在我们使用真机进行Android应用调试时,无法获得调试信息,错误提示如下:Unable to open log device '/dev/log/main': No such file or dir ...
- (一)CodeMirror - 基本应用
基本引用: <link rel="stylesheet" href="../lib/codemirror.css"> <script src= ...
- hdu 3460
算法:字典树 题意:给你一些单词,有一台打印机只能进行以下三种操作 1.读入 2.删除 3.打印 让你输出最少的操作次数将这些单词全部打印出来: (字典树节点-1)*2 表示读入和删除操作: 打印操 ...
- hdu5347 MZL's chemistry(打表)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud MZL's chemistry Time Limit: 2000/1000 MS ...
- Windows下Mysql解压缩版配置安装与卸载
安装: ①解压Mysql到合适的位置! ②以管理员身份运行命令提示符(cmd),cd C:\Documents and Settings\Administrator\桌面\mysql-5.6.24-w ...
- Windows Server 2003 SP2企业版ISO下载, windows2003系统下载,2003系统下载,2003系统
Windows Server 2003 SP2 企业版ISO下载(真正企业免激活版) 此版本适合作为一个新系统来安装,也适合在虚拟机中安装 点评:Windows Server 2003 SP2 企业版 ...
- gridview动态生成列
// 有连接的列 if (!String.IsNullOrWhiteSpace(filedModel.C_SqlDetail)) { HyperLinkField hyperColumn = new ...
- 在CentOS上安装FFMPEG和Gstream-ffmpeg
当我们用CentOS7自带的源时,是yum search不到标题上述的两个相关的包的,而opencv需要用到FFmpeg读取视频文件.这就必须安装了. 可以参考FFMPEG官方给出的文档: http: ...
- 【转】repo 的一些用法和理解-不错
原文网址:http://blog.csdn.net/yasin_lee/article/details/5975068 repo的用法(zz) 注:repo只是google用Python脚本写的调用g ...
- 利用btrace工具监控在线运行java程序
一.作用 可以用于对运行中java程序进行诊断监控分析,也可以用于开发阶段查看一些异常信息或者调用过程(如有些第三方代码没有源代码,不便于debug调试). 注:如果用于对在线运行系统的诊断,需 ...