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】关于存储过程调用过程中事务的点点滴滴的更多相关文章

  1. SQL Server 2008 安装过程中遇到“性能计数器注册表配置单元一致性”检查失败 问题的解决方法

    操作步骤: 1. 在 Microsoft Windows 2003 或 Windows XP 桌面上,依次单击"开始"."运行",然后在"打开&quo ...

  2. FormatMessage与GetLastError配合使用,排查windows api调用过程中的错误

    前一段时间在学习windows api调用过程中,遇到过一些调用错误或者程序没能显示预期的结果,或者直接出现vc运行时错误. 这对新手来说是司空见惯的事,因为不太熟悉难免会出错,出错的信息如果能显示很 ...

  3. SQL Server 2008安装过程中的一些问题和心得

    开博客已经好久了,但一直没有用起来,也有很多"老人"劝诫我,好记性不如烂笔头,于是一年后的我重拾博客,打算记录一些我在计算机方面遇到的一些问题和心得. 前几天重装了Win10系统, ...

  4. C#调用SQL中的存储过程中有output参数,存储过程执行过程中返回信息

      C#调用SQL中的存储过程中有output参数,类型是字符型的时候一定要指定参数的长度.不然获取到的结果总是只有第一字符.本人就是由于这个原因,折腾了很久.在此记录一下,供大家以后参考! 例如: ...

  5. SQL Server 2017 安装过程中的一点说明(有点意思)

    会提到:“安装程序无法与下载服务器联系.请提供 Microsoft 机器学习服务器安装文件的位置,然后单击“下一步”.可从以下位置下载安装文件” 的解决方案 安装过程和2016大体一致,机器学习这款更 ...

  6. sql server 2008安装过程中服务器配置出错

    请选择:对所有 SQL Server 服务使用相同的账号: 但这里不能给他设置自己定义的账号和密码 ( 例如下面设置它的账号为 sa ,密码为 654321) 就会发生错误:

  7. sql server存储过程调用C#编写的DLL文件

    新建C#类库,编译. 引用 using Microsoft.SqlServer.Server; 方法 [SqlFunction]public static int GenerateTxt(){ ... ...

  8. SQL SERVER数据库使用过程中系统提示死锁处理办法

    马上双节(国庆节.中秋节)了,这篇文章是双节前的最后一篇,祈祷过节期间,数据库稳定运行,服务器正常发挥.祝大家假期愉快!!!! 任何的数据库都会出现死锁的情况,特别是一些大型的复杂业务,数据库架构的设 ...

  9. sql的存储过程调用

    USE [ChangHong_612]GO/****** Object: StoredProcedure [dbo].[st_MES_GetCodeRule] Script Date: 09/10/2 ...

随机推荐

  1. HttpModule的认识与深入理解及MVC运行机制

    转自:http://kb.cnblogs.com/page/50130/ ASP.NET MVC架构与实战系列之二:理解MVC路由配置 http://www.cnblogs.com/jyan/arch ...

  2. UVA12219

    //by Rujia Liu /* 字符串的对比是缓慢的. 鉴于这道题最多只有四个小写字母, 也就是最多26*4种情况, 我们完全可以用整数来代替字符串. 一种比较简单的做法是把字符串看成一个四位的2 ...

  3. oracle中的数据读取与查找

    数据读取 首先数据块读入到Buffer Cache中,并将其放在LRU(Last Recently Used)链表的MRU(Most Recently Used)端,当需要再次访问该块时可以直接从bu ...

  4. struts2的action的知识点和利用action向页面注入值的操作

    1.      Action的顺序,会先搜索指定名字下的包的action,如果找不到会去搜索默认路径下的包下的action. 2.      如果没有给action设置值,那么action会有一些默认 ...

  5. ios开发——仿新版iBooks书本打开与关闭动画

    IOS新版iBooks吸引人的地方除了有干净整洁的界面.方便灵活的操作以及大容量的书籍容量以外.还有其优秀的用户交互,尤其是其动画的使用.打开一本书时书本缓慢放大并打开.关闭一本书后书本关闭并回到原位 ...

  6. 【转】C++笔试题汇总

    原文:http://www.cnblogs.com/ifaithu/articles/2657663.html C#C++C多线程面试1.static有什么用途?(请至少说明两种)1)在函数体,一个被 ...

  7. Python 类型的分类

    1.存储模型,对象可以保存多少个值.如果只能保存一个值,是原子类型.如果可以保存多个值,是容器类型.数值是原子类型,元组,列表,字典是容器类型.考虑字符串,按道理,字符串应该是容器类型,因为它包含多个 ...

  8. iOS开发笔记系列-基础7(C语言特性)

    Objective-C是C语言的扩展,因此,也具备很多C语言的基本特性,这里只罗列部分. 块(Blocks) 块是对C语言的一种扩展,它并未作为标准ANSI C所定义的部分,而是Apple添加到语言中 ...

  9. mbstowcs_s实现wchar_t转成char

    把char*转换为wchar_t* 用stdlib.h中的mbstowcs_s函数,可以通过下面的例子了解其用法: char*CStr = "string to convert"; ...

  10. xcode 左边导航栏中,类文件后面的标记“A”,"M","?"……等符号的含义???

    "M" = Locally modified    "U" = Updated in repository  "A" = Locally a ...