T-Sql(二)事务(Transaction)

简介:

 今天讲下T-Sql语法中事务的用法,事务在项目中一般用的很少,主要用于转账,或是一些多表操作,第一步完成不了滚回,不执行接下的步骤。要么都不完成要么都完成,这是事务的特征。

  语法很简单,示例代码如下:

复制代码
 1 create database Transaction_9_30
 2 use Transaction_9_30
 3 drop table Zanghui
 4 create schema Jago 
 5 create table Jago.Zhanghui
 6 (
 7     ID int primary key,
 8     Balance int not null
 9 )
10 insert into Jago.Zhanghui(ID,Balance) values(1,1000);
11 insert into Jago.Zhanghui(ID,Balance) values(2,3000);
12 update Jago.Zhanghui set Balance=1000 where ID=1;
13 update Jago.Zhanghui set Balance=3000 where ID=2;
14 select *from Jago.Zhanghui
15 
16 begin transaction t1;                    --例子:转帐操作;一个表(id,balance)                               
17     declare @v bigint;                  --要求利用事务:
18     set @v = 0;
19     update Jago.Zhanghui set Balance=Balance-200 where ID=1;
20     if not exists(select *from Jago.Zhanghui where ID=1)
21         begin
22             --raiserror('asdfsdf',16,-1)
23             set @v = @v + 1;
24         end    
25     --set @v = @v + @@error;
26     print @v;
27     update Jago.Zhanghui set Balance=Balance+200 where ID=2;
28     if not exists(select *from Jago.Zhanghui where ID=2)
29         begin
30             --update Jago.Zhanghui set Balance=Balance+200 where ID=1;    
31             --raiserror('asdfsdf',16,-1)
32             set @v = 1;
33         end
34     
35     if(@v = 0)
36         begin
37             print @v
38             commit tran t1;
39         end
40     else
41         begin
42             print @v
43             rollback tran t1;
44         end
45 --commit transaction t1
46         
复制代码

 



本文转自田园里的蟋蟀博客园博客,原文链接:http://www.cnblogs.com/xishuai/p/3191712.html,如需转载请自行联系原作者
相关文章
|
7月前
|
SQL 存储 数据库
sql事务、视图和索引
sql事务、视图和索引
|
4月前
|
SQL 数据库 数据安全/隐私保护
SQL Server数据库Owner导致事务复制log reader job无法启动的解决办法
【8月更文挑战第14天】解决SQL Server事务复制Log Reader作业因数据库所有者问题无法启动的方法:首先验证数据库所有者是否有效并具足够权限;若非,使用`ALTER AUTHORIZATION`更改为有效登录名。其次,确认Log Reader使用的登录名拥有读取事务日志所需的角色权限。还需检查复制配置是否准确无误,并验证Log Reader代理的连接信息及参数。重启SQL Server Agent服务或手动启动Log Reader作业亦可能解决问题。最后,审查SQL Server错误日志及Windows事件查看器以获取更多线索。
|
1月前
|
SQL Oracle 关系型数据库
[SQL]事务
本文介绍了事务处理的基本概念,包括事务的四大特性(原子性、一致性、隔离性、持久性)及生命周期。文章还详细解释了事务的保存点、四种事务隔离级别及其异常读现象,并提供了设置事务隔离级别的方法。最后,作者建议读者深入学习相关理论以更好地理解事务隔离级别。
47 0
|
3月前
|
SQL 安全 数据库
基于SQL Server事务日志的数据库恢复技术及实战代码详解
基于事务日志的数据库恢复技术是SQL Server中一个非常强大的功能,它能够帮助数据库管理员在数据丢失或损坏的情况下,有效地恢复数据。通过定期备份数据库和事务日志,并在需要时按照正确的步骤恢复,可以最大限度地减少数据丢失的风险。需要注意的是,恢复数据是一个需要谨慎操作的过程,建议在执行恢复操作之前,详细了解相关的操作步骤和注意事项,以确保数据的安全和完整。
158 0
|
4月前
|
SQL 监控 供应链
|
4月前
|
SQL 关系型数据库 MySQL
SQL Server 事务执行、回滚
SQL Server 事务执行、回滚
51 0
|
6月前
|
SQL 数据库 索引
SQL中如何实现事务?
【6月更文挑战第17天】SQL中如何实现事务?
52 2
|
6月前
|
SQL 关系型数据库 MySQL
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)一
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)一
48 5
|
6月前
|
SQL 存储 关系型数据库
Mysql-事务-锁-索引-sql优化-隔离级别
Mysql-事务-锁-索引-sql优化-隔离级别
|
6月前
|
SQL 存储 关系型数据库
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)二
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)二
47 0