Sqlserver 存储过程中结合事务的代码
2024-10-11 08:32:04
Sqlserver 存储过程中结合事务的代码
--方式一
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[USP_ProcedureWithTransaction_Demo]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[USP_ProcedureWithTransaction_Demo]
GO
-- =============================================
-- Author: <ChengXiaoming>
-- Create date: <2010-06-11>
-- Description: <Demo:存储过程中使用事务>
-- =============================================
Create PROCEDURE [dbo].[USP_ProcedureWithTransaction_Demo]
As
Begin
SET XACT_ABORT ON
Begin Transaction
Insert Into Lock(LockTypeID) Values('A')--此语句将出错,LockTypeID为Int类型
Update Lock Set LockTypeID = 2 Where LockID = 32
Commit Transaction
SET XACT_ABORT OFF
End
GO
--方式二
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[USP_ProcedureWithTransaction_Demo]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[USP_ProcedureWithTransaction_Demo]
GO
-- =============================================
-- Author: <ChengXiaoming>
-- Create date: <2010-06-11>
-- Description: <Demo:存储过程中使用事务>
-- =============================================
Create PROCEDURE [dbo].[USP_ProcedureWithTransaction_Demo]
As
Begin
Begin Transaction
Insert Into Lock(LockTypeID) Values('A')--此语句将出错,LockTypeID为Int类型
Update Lock Set LockTypeID = 1 Where LockID = 32
Commit Transaction
If(@@ERROR <> 0)
Rollback Transaction
End
GO
--方式三
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[USP_ProcedureWithTransaction_Demo]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[USP_ProcedureWithTransaction_Demo]
GO
-- =============================================
-- Author: <ChengXiaoming>
-- Create date: <2010-06-11>
-- Description: <Demo:存储过程中使用事务>
-- =============================================
Create PROCEDURE [dbo].[USP_ProcedureWithTransaction_Demo]
As
Begin
Begin Try
Begin Transaction
Update Lock Set LockTypeID = 1 Where LockID = 32--此语句将出错,LockTypeID为Int类型
Insert Into Lock(LockTypeID) Values('A')
Commit Transaction
End Try
Begin Catch
Rollback Transaction
End Catch
End
GO
Exec [USP_ProcedureWithTransaction_Demo]
最新文章
- Git:Git初体验——Git安装配置
- java并发控制:lock
- python获取字典的key列表
- Linux命令(23)grep命令的使用
- struts2拦截器
- properties 配置文件中值换行的问题
- PHP的Tag标签
- 大熊君说说JS与设计模式之------命令模式Command
- 多窗体之间方法调用 z
- Python爬虫之豆瓣-新书速递-图书解析
- java 内部类的使用
- InstallShield : 如何查找编译后的 Merge Module存放路径
- [core java学习笔记][第十一章异常断言日志调试]
- 分布式发布订阅消息系统Kafka
- PAT 团体程序设计天梯赛-练习集 L1-023. 输出GPLT
- 解决微信浏览器中无法一键拨号问题tel
- nodeJS之crypto模块md5和Hmac加密
- 正试图在os加载程序锁内执行托管代码。不要尝试在DllMain或映像初始化函数内运行托管代码 问题解决方法
- MIME 内容类型
- 【BZOJ3672】【UOJ#6】【NOI2014】随机数生成器
热门文章
- Dom lesson1
- windows和linux下mysql的重启命令
- iOS viewDidAppear 和 viewWillAppear
- Java for LeetCode 146 LRU Cache 【HARD】
- cc.game
- Java虚拟机支持的最大内存限制
- 禁用SettingSyncHost.exe
- Tomcat 解决The code of method _jspService(HttpServletRequest, HttpServletResponse) is exceeding the 65535 bytes limit
- javaweb实现验证码功能
- errno 错误码