你的位置:首页 > 数据库

[数据库]SQL事务回滚样例


选课系统,当同意学号选课数量超过则回滚事务,符合条件则正常插入数据

--开始一个事务处理
Begin Tran T1

--执行插入操作
insert into Courselist values('20100021','01');
insert into Courselist values('20100021','02');
insert into Courselist values('20100021','03');
insert into Courselist values('20100021','04');
insert into Courselist values('20100021','05');
--判断同一学号的选课数量是否符合
IF(select COUNT(StudentID) as cnt from Courselist where StudentID='20100021')>4
BEGIN
--不符合,回滚事务
rollback Tran T1
END
ELSE
BEGIN
--符合,提交事务
commit Tran T1
END