SQL事务(Transaction)⽤法介绍及回滚实例
事务(Transaction)是并发控制的单位,是⽤户定义的⼀个操作序列。这些操作要么都做,要么都不做,是⼀个不可分割的⼯作单位。通过事务,SQL Server能将逻辑相关的⼀组操作绑定在⼀起,以便服务器保持数据的完整性
当对多个表进⾏更新的时候,某条执⾏失败。为了保持数据的完整性,需要使⽤事务回滚。
显⽰设置事务
代码如下复制代码
begin try
begin transaction
insert into shiwu (asd) values ('aasdasda');
commit transaction
end try
begin catch
select ERROR_NUMBER() as errornumber
rollback transaction
end catch
隐式设置事务
代码如下复制代码
set implicit_transactions on; -- 启动隐式事务
go
begin try
insert into shiwu (asd) values ('aasdasda');
insert into shiwu (asd) values ('aasdasda');
commit transaction;
end try
begin catch
select ERROR_NUMBER() as errornumber
rollback transaction; --回滚事务
end catch
set implicit_transactions off; --关闭隐式事务
go
显⽰事务以下语句不能使⽤,隐式事务可以
代码如下复制代码
alter database;
backup;
create database;
drop database;
reconfigure;
restore;
update statistics;
显⽰事务可以嵌套使⽤
代码如下复制代码
--创建存储过程
create procedure qiantaoProc
@asd nchar(10)
as
begin
begin try
begin transaction innerTrans
save transaction savepoint --创建事务保存点
insert into shiwu (asd) values (@asd);
commit transaction innerTrans
end try
begin catch
rollback transaction savepoint --回滚到保存点
commit transaction innerTrans
end catch
end
end
go
begin transaction outrans
exec qiantaoProc 'asdasd';
rollback transaction outrans
事务嵌套,回滚外层事务时,如果嵌套内的事务已经回滚过则会有异常。此时需要使⽤事务保存点。如下实例
SQL事务回滚
指定当 Transact-SQL 语句产⽣运⾏时错误时,Microsoft® SQL Server™ 是否⾃动回滚当前事务
⽅案⼀:
代码如下复制代码
SET XACT_ABORT ON--如果产⽣错误⾃动回滚
GO
BEGIN TRAN
INSERT INTO A VALUES (4)
INSERT INTO B VALUES (5)
COMMIT TRAN
也可以使⽤_ConnectionPtr 对象的⽅法: BeginTrans、CommitTrans、RollbackTrans,使⽤该系列函数判断并回滚。⼀旦调⽤了BeginTrans ⽅法, 在调⽤ CommitTrans 或 RollbackTrans 结束事务之前, 将不再⽴即提交所作的任何更改。
⽅案⼆
代码如下复制代码
BEGIN TRANSACTION
INSERT INTO A values (4) ----- 该表含有触发器,UPDATE其他表
IF @@error <> 0 --发⽣错误
BEGIN
ROLLBACK TRANSACTION
END
ELSE
BEGIN
COMMIT TRANSACTION
END
sql事务结合asp两种⽤法
在sql server+ 开发环境下,有两种⽅法能够完成事务的操作,保持数据库的数据完整性;⼀个就是⽤/42850.htm target=_blank >sql存储过程,另⼀个就是在ADO.NET中⼀种简单的事务处理;现在通过⼀个典型的银⾏转账的例⼦来说明⼀下这两个例⼦的⽤法我们先来看看sql存储过程是如何来完成事务的操作的:⾸先创建⼀个表:
代码如下复制代码create database aaaa --创建⼀个表,包含⽤户的帐号和钱数gouse aaaacreate table bb( ID int not null primary key, --帐号 moneys money --转账⾦额)insert into bb values ('1','2000') --插⼊两条数据insert into bb values ('2','3000')⽤这个表创建⼀个存储过程:create procedure mon --创建存储过程,定义⼏个变量
@toID int, --接收转账的账户
@fromID int , --转出⾃⼰的账户
@momeys money --转账的⾦额
as
begin tran --开始执⾏事务
update bb set moneys=moneys-@momeys where ID=@fromID -执⾏的第⼀个操作,转账出钱,减去转出的⾦额
update bb set moneys=moneys+@momeys where ID=@toID --执⾏第⼆个操作,接受转账的⾦额,增加
if @@error<>0 --判断如果两条语句有任何⼀条出现错误
begin rollback tran –开始执⾏事务的回滚,恢复的转账开始之前状态
return 0
end
go
else --如何两条都执⾏成功
sqltransaction什么意思begin commit tran 执⾏这个事务的操作
return 1
end
go
接下来看看 是如何调⽤这个存储过程的:
代码如下复制代码
protected void Button1_Click(object sender, EventArgs e)
{
SqlConnection con =new SqlConnection(@"Data Source=.SQLEXPRESS;database=aaaa;uid=sa;pwd=jcx"); //连接字符串 SqlCommand cmd = new SqlCommand("mon",con); //调⽤存储过程
cmd.CommandType = CommandType.StoredProcedure;
con.Open();
SqlParameter prar = new SqlParameter();//传递参数
cmd.Parameters.AddWithValue("@fromID", 1);
cmd.Parameters.AddWithValue("@toID", 2);
cmd.Parameters.AddWithValue("@momeys",Convert.ToInt32( 1.Text) );
cmd.Parameters.Add("@return", "").Direction = ParameterDirection.ReturnValue;//获取存储过程的返回值
cmd.ExecuteNonQuery();
string value = cmd.Parameters["@return"].Value.ToString();//把返回值赋值给value
if (value == "1")
{
Label1.Text = "添加成功";
}
else
{
Label1.Text = "添加失败";
}
}
这个也就是在存储过程⾥添加事务,再来看看不在数据库写sql存储过程,ADO.NET是如何处理事务的:
代码如下复制代码protected void Button2_Click(object sender, EventArgs e)
protected void Button2_Click(object sender, EventArgs e)
{
SqlConnection con = new SqlConnection(@"Data Source=.SQLEXPRESS;database=aaaa;uid=sa;pwd=jcx");
con.Open();
SqlTransaction tran = con.BeginTransaction();//先实例SqlTransaction类,使⽤这个事务使⽤的是con 这个连接,使⽤BeginTransaction这个⽅法来开始执⾏这个事务
SqlCommand cmd = new SqlCommand();
cmd.Connection = con;
cmd.Transaction = tran;
try
{
//在try{} 块⾥执⾏sqlcommand命令,
cmd.CommandText = "update bb set moneys=moneys-'" + Convert.ToInt32(TextBox1.Text) + "' where ID='1'";
cmd.ExecuteNonQuery();
cmd.CommandText = "update bb set moneys=moneys+' aa ' where ID='2'";
cmd.ExecuteNonQuery();
tran.Commit();//如果两个sql命令都执⾏成功,则执⾏commit这个⽅法,执⾏这些操作
Label1.Text = "添加成功";
}
catch
{
Label1.Text = "添加失败";
tran.Rollback();//如何执⾏不成功,发⽣异常,则执⾏rollback⽅法,回滚到事务操作开始之前;
}
}
这就是两个事务不同⽤法的简单例⼦,ADO.NET 事务处理的⽅法看起来⽐较简单,但是他要使⽤同
⼀个连接来执⾏这些操作,要是同时使⽤⼏个数据库来⽤⼀个事务执⾏,这样就⽐较繁琐,但是要是⽤sql存储过程,这样就相对⽐较简单
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论