【SQL】关于存储过程调用过程中事务的点点滴滴
1、调用两个存储过程
----------------------------------------------------------------
-- 表[dbo].[aaa_test]中[id]为主键
---------------------------------------------------------------- -- 存储过程1
ALTER PROCEDURE [dbo].[aaa_test_proc1]
@p_id int,
@p_name varchar(50)
AS
BEGIN
INSERT INTO [dbo].[aaa_test]
([id]
,[name])
VALUES
(@p_id
,@p_name)
END ---------------------------------------------------------------- -- 存储过程2
ALTER PROCEDURE [dbo].[aaa_test_proc2]
@p_id int,
@p_name varchar(50)
AS
BEGIN
INSERT INTO [dbo].[aaa_test]
([id]
,[name])
VALUES
(@p_id
,@p_name)
END ---------------------------------------------------------------- -- 调用两个存储过程
exec dbo.aaa_test_proc1 '','事务测试1'
exec dbo.aaa_test_proc2 '','事务测试2' ---------------------------------------------------------------- -- 结果
--(1 行受影响)
--消息 2627,级别 14,状态 1,过程 aaa_test_proc2,第 11 行
--违反了 PRIMARY KEY 约束 'PK_aaa_test'。不能在对象 'dbo.aaa_test' 中插入重复键。
--语句已终止。 -- 表[dbo].[aaa_test]:
id |
name |
1 |
事务测试1 |
-- 【结论】:不明确指定事务时,两次存储过程调用是分开的两个事务
2、在同一个事务中调用两个存储过程,没有事务的嵌套
----------------------------------------------------------------
-- 表[dbo].[aaa_test]中[id]为主键
---------------------------------------------------------------- -- 存储过程1
ALTER PROCEDURE [dbo].[aaa_test_proc1]
@p_id int,
@p_name varchar(50)
AS
BEGIN
INSERT INTO [dbo].[aaa_test]
([id]
,[name])
VALUES
(@p_id
,@p_name)
END ---------------------------------------------------------------- -- 存储过程2
ALTER PROCEDURE [dbo].[aaa_test_proc2]
@p_id int,
@p_name varchar(50)
AS
BEGIN
INSERT INTO [dbo].[aaa_test]
([id]
,[name])
VALUES
(@p_id
,@p_name)
END ---------------------------------------------------------------- -- 调用两个存储过程
BEGIN TRY
BEGIN TRAN
exec dbo.aaa_test_proc1 '','事务测试1'
exec dbo.aaa_test_proc2 '','事务测试2'
COMMIT TRAN
END TRY
BEGIN CATCH
ROLLBACK TRAN
END CATCH ---------------------------------------------------------------- -- 结果
--(1 行受影响) -- 表[dbo].[aaa_test]:
id |
name |
-- 【结论】:在同一个事务中调用多个存储过程,其中一个出错后,全部回滚。
3、事务嵌套
----------------------------------------------------------------
-- 表[dbo].[aaa_test]中[id]为主键
---------------------------------------------------------------- -- 存储过程1
ALTER PROCEDURE [dbo].[aaa_test_proc1]
@p_id int,
@p_name varchar(50)
AS
BEGIN
BEGIN TRY
BEGIN TRAN
INSERT INTO [dbo].[aaa_test]
([id]
,[name])
VALUES
(@p_id
,@p_name)
COMMIT TRAN
END TRY
BEGIN CATCH
ROLLBACK TRAN
END CATCH
END ---------------------------------------------------------------- -- 存储过程2
ALTER PROCEDURE [dbo].[aaa_test_proc2]
@p_id int,
@p_name varchar(50)
AS
BEGIN
INSERT INTO [dbo].[aaa_test]
([id]
,[name])
VALUES
(@p_id
,@p_name)
END ---------------------------------------------------------------- -- 调用两个存储过程
BEGIN TRY
BEGIN TRAN
exec dbo.aaa_test_proc1 '','事务测试1'
exec dbo.aaa_test_proc2 '','事务测试2'
COMMIT TRAN
END TRY
BEGIN CATCH
ROLLBACK TRAN
END CATCH ---------------------------------------------------------------- -- 结果
--(1 行受影响) -- 表[dbo].[aaa_test]:
id |
name |
-- 【结论】:事务嵌套时,以最外层事务的执行情况为准。
-- 例子中,虽然在第一个存储过程的子事务中有commit tran,且第一个存储过程执行没有问题。
-- 但是因为第二个存储过程因为主键冲突执行失败,所以最外层事务会进行回滚,因此测试表中没有插入任何数据。
-----打完收工-----
【SQL】关于存储过程调用过程中事务的点点滴滴的更多相关文章
- SQL Server 2008 安装过程中遇到“性能计数器注册表配置单元一致性”检查失败 问题的解决方法
操作步骤: 1. 在 Microsoft Windows 2003 或 Windows XP 桌面上,依次单击"开始"."运行",然后在"打开&quo ...
- FormatMessage与GetLastError配合使用,排查windows api调用过程中的错误
前一段时间在学习windows api调用过程中,遇到过一些调用错误或者程序没能显示预期的结果,或者直接出现vc运行时错误. 这对新手来说是司空见惯的事,因为不太熟悉难免会出错,出错的信息如果能显示很 ...
- SQL Server 2008安装过程中的一些问题和心得
开博客已经好久了,但一直没有用起来,也有很多"老人"劝诫我,好记性不如烂笔头,于是一年后的我重拾博客,打算记录一些我在计算机方面遇到的一些问题和心得. 前几天重装了Win10系统, ...
- C#调用SQL中的存储过程中有output参数,存储过程执行过程中返回信息
C#调用SQL中的存储过程中有output参数,类型是字符型的时候一定要指定参数的长度.不然获取到的结果总是只有第一字符.本人就是由于这个原因,折腾了很久.在此记录一下,供大家以后参考! 例如: ...
- SQL Server 2017 安装过程中的一点说明(有点意思)
会提到:“安装程序无法与下载服务器联系.请提供 Microsoft 机器学习服务器安装文件的位置,然后单击“下一步”.可从以下位置下载安装文件” 的解决方案 安装过程和2016大体一致,机器学习这款更 ...
- sql server 2008安装过程中服务器配置出错
请选择:对所有 SQL Server 服务使用相同的账号: 但这里不能给他设置自己定义的账号和密码 ( 例如下面设置它的账号为 sa ,密码为 654321) 就会发生错误:
- sql server存储过程调用C#编写的DLL文件
新建C#类库,编译. 引用 using Microsoft.SqlServer.Server; 方法 [SqlFunction]public static int GenerateTxt(){ ... ...
- SQL SERVER数据库使用过程中系统提示死锁处理办法
马上双节(国庆节.中秋节)了,这篇文章是双节前的最后一篇,祈祷过节期间,数据库稳定运行,服务器正常发挥.祝大家假期愉快!!!! 任何的数据库都会出现死锁的情况,特别是一些大型的复杂业务,数据库架构的设 ...
- sql的存储过程调用
USE [ChangHong_612]GO/****** Object: StoredProcedure [dbo].[st_MES_GetCodeRule] Script Date: 09/10/2 ...
随机推荐
- SSH三大框架整合使用的配置文件 注解实现
1 Struts.xml 使用拦截器 <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE str ...
- Autofac实例生命周期
1.默认,每次请求都会返回一个实例 builder.RegisterType<X>().InstancePerDependency(); 2.Per Lifetime Scope:这个作用 ...
- mac下批量删除.svn文件
mac下.svn是隐藏文件,而且即使我们调成可见的,一个一个删也很麻烦.今天正好同事问起来这个命令,于是想可能有些人也需要,于是还是放到博客里吧 命令比较简单,其实就是一条linux命令,打开终端,首 ...
- 【M8】了解各种不同意义的new和delete
1.首先考虑new operator,new operator 可以认为做了三件事情:a.调用operator new分配一块内存:b.在这块内存上调用构造方法构造对象:返回指针. 2.operato ...
- Cocos2d-x学习笔记(10)(CCMenu菜单)
1.CCMenu创建方式 CCMenu* menu = CCMenu::create(cocos2d::CCMenuItem* item,--)參数为CCMenuItem菜单项的对象可变參数列表 2. ...
- delphi queryCommandState
如何 获取当前光标所在的字符属性 关键点 function queryCommandState(const cmdID: WideString): WordBool; safecall; 粗体 斜体 ...
- delphi 14 内容编辑
撤销 重做 - 复制 剪切 粘贴 删除 - 全选 不选 ///编辑 ///撤销 WebBrowser1.ExecWB(OLECMDID_REDO ,1); ///重做 WebB ...
- 安卓模拟器BlueStacks 安装使用教程(图解)
系统要求 操作系统 Win XP SP3/Vista/Win 7/Win 8/Win 8.1 所需的运行环境 Win XP用户请先升级到SP3 并安装Windows Installer 4.5 Win ...
- [Angular 2] Value Providers & @Inject
Dependecies aren’t always objects created by classes or factory functions. Sometimes, all we really ...
- android150 笔记
1. 什么是Activity? 四大组件之一,一般的,一个用户交互界面对应一个activity,界面的容器. setContentView() ,// 要显示的布局 button.setOnclick ...