SQL基础【十八、事物】(sql事物慎用,还是写业务逻辑代码好一些,入伙涉及到更换数据啥的很麻烦!)(二)

简介: SQL基础【十八、事物】(sql事物慎用,还是写业务逻辑代码好一些,入伙涉及到更换数据啥的很麻烦!)(二)

3、事务设置保存点


利用save transaction   和rollback transaction 语句:


---开启事务
begin tran
--错误捕捉机制,看好啦,这里也有的。并且可以嵌套。
begin try    
   --语句正确
   insert into lives (Eat,Play,Numb) values ('猪肉','足球',1)   
    --加入保存点
   save tran pigOneIn
   insert into lives (Eat,Play,Numb) values ('猪肉','足球',2)
   insert into lives (Eat,Play,Numb) values ('狗肉','篮球',3)
end try
begin catch
   select Error_number() as ErrorNumber,  --错误代码
          Error_severity() as ErrorSeverity,  --错误严重级别,级别小于10 try catch 捕获不到
          Error_state() as ErrorState ,  --错误状态码
          Error_Procedure() as ErrorProcedure , --出现错误的存储过程或触发器的名称。
          Error_line() as ErrorLine,  --发生错误的行号
          Error_message() as ErrorMessage  --错误的具体信息
   if(@@trancount>0) --全局变量@@trancount,事务开启此值+1,他用来判断是有开启事务
      rollback tran   
end catch
if(@@trancount>0)
rollback tran pigOneIn 
--表本身为空表,ID ,Numb为int 类型,其它为nvarchar类型
select * from live


微信图片_20220110161911.png


注:事务保存点以上的都将影响,当提交事务以后,只有保存点之前的语句被执行。


事务保存点示例:


在SQL Server中使用rollback会回滚所有的未提交事务状态,但是有些时候我们只需要回滚部分语句,把不需要回滚的语句提到事务外面来,虽然是个方法,但是却破坏了事务的ACID。


SQL中使用事务保存点,即可解决这个问题。


SQL 事务中存在错误信息 进行Catch 回滚事务时


begin try
    begin tran A
    insert into dbo.lives ( Eat, Play, Numb, times ) values ( 'A', '', 0, getdate() )
    select 1/0    --错误信息
    save tran B_Point
    insert into dbo.lives ( Eat, Play, Numb, times ) values ( 'B', '', 0, getdate() )
    save tran C_Point
    insert into dbo.lives ( Eat, Play, Numb, times ) values ( 'C', '', 0, getdate() )
    rollback tran B_Point    --回滚事务点B_Point 即事务点下的部分都回滚
    select 1
    commit tran A    --提交整个事务信息
end try
begin catch
    select 2
    rollback tran B_Point    --回滚事务点B_Point 即事务点下的部分都回滚
    commit tran A    --提交整个事务信息
end catch
go
select * from dbo.lives
g


微信图片_20220110161936.png


微信图片_20220110161940.png


SQL回滚局部信息时:


begin try
    begin tran A
    insert into dbo.lives ( Eat, Play, Numb, times ) values ( 'A', '', 0, getdate() )
    --select 1/0    --错误信息
    save tran B_Point
    insert into dbo.lives ( Eat, Play, Numb, times ) values ( 'B', '', 0, getdate() )
    save tran C_Point
    insert into dbo.lives ( Eat, Play, Numb, times ) values ( 'C', '', 0, getdate() )
    rollback tran B_Point    --回滚事务点B_Point 即事务点下的部分都回滚
    select 1
    commit tran A    --提交整个事务信息
end try
begin catch
    select 2
    rollback tran B_Point    --回滚事务点B_Point 即事务点下的部分都回滚
    commit tran A    --提交整个事务信息
end catch
go
select * from dbo.lives
g


微信图片_20220110162026.png



回滚保存点B时 即保存点以下部分均要回滚,


注:使用保存点 无论try 或 catch 代码块 除提交或回滚保存点外,都要COMMIT或 ROLLBACK完整事务。


使用场景:当操作数据时前校验数据成本太高且数据出错率不高时 可采用.eg:用户下单 检查库存信息是否>0时 可以设置库存量需>=0的约束 当更新库时信息小于0即出错 进行事务回滚 并查询返回当前库存信息。


相关文章
|
5天前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
|
20天前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
27天前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
28天前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
30天前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
140 4
|
1月前
|
SQL 关系型数据库 MySQL
创建SQL数据库的基本步骤与代码指南
在信息时代,数据管理显得尤为重要,其中数据库系统已成为信息技术架构的关键部分。而当我们谈论数据库系统时,SQL(结构化查询语言)无疑是其中最核心的工具之一。本文将详细介绍如何使用SQL创建数据库,包括编写相应的代码和必要的步骤。由于篇幅限制,本文可能无法达到您要求的2000字长度,但会尽量涵盖创建数
31 3
|
26天前
|
SQL 监控 关系型数据库
SQL错误代码1303解析与处理方法
在SQL编程和数据库管理中,遇到错误代码是常有的事,其中错误代码1303在不同数据库系统中可能代表不同的含义
|
30天前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
78 0
|
30天前
|
SQL 分布式计算 关系型数据库
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
34 0
|
30天前
|
SQL 分布式计算 关系型数据库
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
44 0