DECLARE @errorSun INT --定义错误计数器 SET @errorSun=0 --没错为0
UPDATE a SET id=232 WHERE a=1 --事务操作SQL语句 SET @errorSun=@errorSun+@@ERROR --累计是否有错
UPDATE aa SET id=2 WHERE a=1 --事务操作SQL语句 SET @errorSun=@errorSun+@@ERROR --累计是否有错
IF @errorSun<>0 BEGIN PRINT ''有错误,回滚'' ROLLBACK TRANSACTION--事务回滚语句 END ELSE BEGIN PRINT ''成功,提交'' COMMIT TRANSACTION--事务提交语句 END
示例:创建一个存储过程,向两个表中同时插入数据
复制代码 代码如下:
Create proc RegisterUser (@usrName varchar(30), @usrPasswd varchar(30),@age int,@sex varchar(10), @PhoneNum varchar(20), @Address varchar(50) ) as begin begin tran insert into userinfo(userName,userPasswd) values(@usrName,@usrPasswd) if @@error<>0 begin
rollback tran
return -1 end insert into userdoc(userName,age,sex,PhoneNumber,Address)values(@Usrname,@age,@sex,@PhoneNum,@Address) if @@error<>0 begin
use bookdb go begin tran mytran insert into book values(9,"windows2000'',1,22,''出版社'') save tran mysave delete book where book_id=9 rollback tran mysave commit tran go select * from book go
可以知道,上面的语句执行后,在book中插入了一笔记录,而并没有删除。因为使用rollback tran mysave 语句将操作回滚到了删除前的保存点处。 5、标记事务 格式:with mark 例:使用数据库标记将日志恢复到预定义时间点的语句 在事务日志中置入一个标记。请注意,被标记的事务至少须提交一个更新,以标记该日志。
BEGIN TRAN MyMark WITH MARK UPDATE pubs.dbo.LastLogMark SET MarkTime = GETDATE() COMMIT TRAN MyMark
按照您常用的方法备份事务日志。
BACKUP LOG pubs TO DISK=''C:\Backups\Fullbackup.bak'' WITH INIT
现在您可以将数据库恢复至日志标记点。首先恢复数据库,并使其为接受日志恢复做好准备。
RESTORE DATABASE pubs FROM DISK=N''C:\Backups\Fullbackup.bak'' WITH NORECOVERY
use test go create table testback(cola int primary key ,colb char(3)) go insert into testback values(1,''aaa'') insert into testback values(2,''bbb'') insert into testback value(3,''ccc'') go select * from testback go
没有任何结果返回
三、隐式事务 通过 API 函数或 Transact-SQL SET IMPLICIT_TRANSACTIONS ON 语句,将隐性事务模式设置为打开。下一个语句自动启动一个新事务。当该事务完成时,再下一个 Transact-SQL 语句又将启动一个新事务。 当有大量的DDL 和DML命令执行时会自动开始,并一直保持到用户明确提交为止,切换隐式事务可以用SET IMPLICIT_TRANSACTIONS 为连接设置隐性事务模式.当设置为 ON 时,SET IMPLICIT_TRANSACTIONS 将连接设置为隐性事务模式。当设置为 OFF 时,则使连接返回到自动提交事务模式 语句包括: alter table insert open create delete revoke drop select fetch truncate table grant update 示例: 下面使用显式与隐式事务。它使用@@tracount函数演示打开的事务与关闭的事务:
复制代码 代码如下:
use test go set nocount on create table t1(a int) go insert into t1 values(1) go
print ''使用显式事务'' begin tran insert into t1 values(2) print ''事务外的事务数目:''+cast(@@trancount as char(5)) commint tran print ''事务外的事务数目:''+cast(@@trancount as char(5)) go
print go set implicit_transactions on go
print ''使用隐式事务'' go insert into t1 values*4) print''事务内的事务数目:''+cast(@@trancount as char(5)) commint tran print''事务外的事务数目:''+cast(@@trancount as char(5)) go
begin tran declare @rownum1 int --未添加订单的空房数 declare @rownum2 int --添加订单的空房数目 declare @BookID1 int set @BookID1=0 insert into T_BookRoomInfo(RoomID,CustomerName,CustomerCardID,Discount, EnterTime,DepositMoney,Memo,UserID,UpdTime) values (@RoomID,@CustomerName,@CustomerCardID,@Discount, getdate(),@DepositMoney,@Memo,@UserID,getdate()) select @BookID1=@@IDENTITY if(@BookID1<>0) begin select @rownum1=count(1) from T_Room where IsEmploy=0 update T_Room set IsEmploy=1 where RoomID=@RoomID select @rownum1=count(1) from T_Room where IsEmploy=0
if(@rownum1<=@rownum2) begin rollback tran end else begin commit tran end end else begin rollback tran end
您可能感兴趣的文章:
MSSQL事务的存储过程
c#实现sqlserver事务处理示例
使用Sqlserver事务发布实现数据同步(sql2008)
SQLServer分布式事务问题
Sqlserver 存储过程中结合事务的代码
Transactional replication(事务复制)详解之如何跳过一个事务
@Transactional 事务说明
这里面有几点需要大家留意: A. 一个功能是否要事务,必须纳入设计、编码考虑。不能仅仅完成了基本功能就ok。 B. 如果加了事务,必须做好开发环境测试(测试环境也尽量触发异常、测试回滚),确保事务生效。 C. 以下列了事务使用过程的注意事项,请大家留意。 1. 不要在接口上声明@Transactional ,而要在具体类的方法上使用 @Transactional 注解,否则注解可能无效。 2.不要图省事,将@Transactional放置在类级的声明中,放在类声明,会使得所有方法都有事务。故@Transactional应该放在方法级别,不需要使用事务的方法,就不要放置事务,比如查询方法。否则对性能是有影响的。 3.使用了@Transactional的方法,对同一个类里面的方法调用, @Transactional无效。比如有一个类Test,它的一个方法A,A再调用Test本类的方法B(不管B是否public还是private),但A没有声明注解事务,而B有。则外部调用A之后,B的事务是不会起作用的。(经常在这里出错) 4.使用了@Transactional的方法,只能是public,@Transactional注解的方法都是被外部其他类调用才有效,故只能是public。道理和上面的有关联。故在 protected、private 或者 package-visible 的方法上使用 @Transactional 注解,它也不会报错,但事务无效。 5.经过在ICORE-CLAIM中测试,效果如下: A.抛出受查异常XXXException,事务会回滚。 B.抛出运行时异常NullPointerException,事务会回滚。 C.Quartz中,execute直接调用加了@Transactional方法,可以回滚;间接调用,不会回滚。(即上文3点提到的) D.异步任务中,execute直接调用加了@Transactional方法,可以回滚;间接调用,不会回滚。(即上文3点提到的) E.在action中加上@Transactional,不会回滚。切记不要在action中加上事务。 F.在service中加上@Transactional,如果是action直接调该方法,会回滚,如果是间接调,不会回滚。(即上文3提到的) G.在service中的private加上@Transactional,事务不会回滚。
db_user="root"
db_passwd="root"
db_name="db_test"
# the directory for story your backup file.you shall change this dir
backup_dir="/usr/software/backup/mysqlbackup"
# date format for backup file (dd-mm-yyyy)
time="$(date +"%Y%m%d%H%M%S")"
mysqldump -u$db_user -p$db_passwd $db_name > "$backup_dir/$db_name"_"$time.sql"
<insertid="insertProduct-ORACLE"parameterClass="product"><selectKeyresultClass="int"type="pre"keyProperty="id" >
SELECT STOCKIDSEQUENCE.NEXTVAL AS VALUE FROM DUAL
</selectKey>
insert into PRODUCT (PRD_ID,PRD_DESCRIPTION) values (#id#,#description#)
</insert>
wget ftp://ftp.freetds.org/pub/freetds/stable/freetds-patched.tar.gz
tar -zxvf freetds-patched.tar.gz
cd freetds-*
./configure --prefix=/usr/local/freetds --with-tdsver=auto --enable-msdblib --with-gnu-ld --enable-shared --enable-static
make && make install
安装 mssql
wget http://cn2.php.net/distributions/php-5.6.22.tar.gz
tar -zxvf php-5.6.22.tar.gz
cd php-*/ext/mssql
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config --with-mssql=/usr/local/freetds
make && make install
wget ftp://ftp.freetds.org/pub/freetds/stable/freetds-patched.tar.gz
tar -zxvf freetds-patched.tar.gz
cd freetds-*
./configure --prefix=/usr/local/freetds --with-tdsver=auto --enable-msdblib --with-gnu-ld --enable-shared --enable-static
make && make install
安装 pdo_dblib
wget http://cn2.php.net/distributions/php-5.6.22.tar.gz
tar -zxvf php-5.6.22.tar.gz
cd php-*/ext/pdo_dblib
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config --with-pdo-dblib=/usr/local/freetds
make && make install