存储过程中的简单事务处理---SQLServer2005系列
2008-04-16 09:14
417 查看
一. 添加记录
需要事务支持,如果上下文环境中不存在事务,新启动一个事务,否则利用已存在的事务.
-- =============================================
-- Author: <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
CREATE PROCEDURE [dbo].[AddJob]
@jobName nvarchar(50),
@added bit output
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
DECLARE @errorCode int
SET @errorCode = 0
--Transaction identity. 1:Created a new transaction. 0:Use old transaction.
DECLARE @tranStarted bit
SET @tranStarted = 0
--Create a new transaction if there is not a transaction.
IF( @@TRANCOUNT = 0 )
BEGIN
BEGIN TRANSACTION
SET @tranStarted = 1
END
ELSE
SET @tranStarted = 0
--Adding operation.
INSERT INTO dbo.Job(JobName)
VALUES (@jobName)
IF ( @@ERROR <> 0 )
BEGIN
SET @errorCode = -1
GOTO Cleanup
END
IF ( @tranStarted = 1 )
BEGIN
SET @tranStarted = 0
COMMIT TRANSACTION
END
SET @added = 1
RETURN(0)
--Error handler.
Cleanup:
IF( @tranStarted = 1 )
BEGIN
SET @tranStarted = 0
ROLLBACK TRANSACTION
END
SET @added = 0
RETURN @errorCode
END
二. 删除记录(同上)
需要事务支持,如果上下文环境中不存在事务,新启动一个事务,否则利用已存在的事务.
三. 修改记录(同上)
需要事务支持,如果上下文环境中不存在事务,新启动一个事务,否则利用已存在的事务.
[align=left]四. 查询记录[/align]
[align=left] 不需要事务支持.[/align]
[align=left]-- =============================================[/align]
[align=left]-- Author: <Author,,Name>[/align]
[align=left]-- Create date: <Create Date,,>[/align]
[align=left]-- Description: <Description,,>[/align]
[align=left]-- =============================================[/align]
[align=left]CREATE PROCEDURE [dbo].[GetAllJob][/align]
[align=left]AS[/align]
[align=left]BEGIN[/align]
[align=left] -- SET NOCOUNT ON added to prevent extra result sets from[/align]
[align=left] -- interfering with SELECT statements.[/align]
[align=left] SET NOCOUNT ON;[/align]
[align=left] [/align]
[align=left] SELECT JobId, JobName [/align]
[align=left] FROM Job[/align]
[align=left]END[/align]
需要事务支持,如果上下文环境中不存在事务,新启动一个事务,否则利用已存在的事务.
-- =============================================
-- Author: <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
CREATE PROCEDURE [dbo].[AddJob]
@jobName nvarchar(50),
@added bit output
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
DECLARE @errorCode int
SET @errorCode = 0
--Transaction identity. 1:Created a new transaction. 0:Use old transaction.
DECLARE @tranStarted bit
SET @tranStarted = 0
--Create a new transaction if there is not a transaction.
IF( @@TRANCOUNT = 0 )
BEGIN
BEGIN TRANSACTION
SET @tranStarted = 1
END
ELSE
SET @tranStarted = 0
--Adding operation.
INSERT INTO dbo.Job(JobName)
VALUES (@jobName)
IF ( @@ERROR <> 0 )
BEGIN
SET @errorCode = -1
GOTO Cleanup
END
IF ( @tranStarted = 1 )
BEGIN
SET @tranStarted = 0
COMMIT TRANSACTION
END
SET @added = 1
RETURN(0)
--Error handler.
Cleanup:
IF( @tranStarted = 1 )
BEGIN
SET @tranStarted = 0
ROLLBACK TRANSACTION
END
SET @added = 0
RETURN @errorCode
END
二. 删除记录(同上)
需要事务支持,如果上下文环境中不存在事务,新启动一个事务,否则利用已存在的事务.
三. 修改记录(同上)
需要事务支持,如果上下文环境中不存在事务,新启动一个事务,否则利用已存在的事务.
[align=left]四. 查询记录[/align]
[align=left] 不需要事务支持.[/align]
[align=left]-- =============================================[/align]
[align=left]-- Author: <Author,,Name>[/align]
[align=left]-- Create date: <Create Date,,>[/align]
[align=left]-- Description: <Description,,>[/align]
[align=left]-- =============================================[/align]
[align=left]CREATE PROCEDURE [dbo].[GetAllJob][/align]
[align=left]AS[/align]
[align=left]BEGIN[/align]
[align=left] -- SET NOCOUNT ON added to prevent extra result sets from[/align]
[align=left] -- interfering with SELECT statements.[/align]
[align=left] SET NOCOUNT ON;[/align]
[align=left] [/align]
[align=left] SELECT JobId, JobName [/align]
[align=left] FROM Job[/align]
[align=left]END[/align]
相关文章推荐
- SQLServer-存储过程中的简单事务处理
- SQLServer-存储过程中的简单事务处理
- 个人学习代码保存:例8.在存储过程中使用简单的事务处理
- 批处理,主键,存储过程和事务
- SQL Server在存储过程中编写事务处理代码的三种方法
- (转) SQL Server在存储过程中编写事务处理代码的三种方法
- Oracle 存储过程的默认值参数和过程中的事务处理
- SQL Server在存储过程中编写事务处理代码的三种方法
- Oracle - 存储过程异常处理事务分析
- PostgreSQL服务过程中的那些事二:Pg服务进程处理简单查询一:开启事务
- 关于存储过程中一个参数表示多个查询条件使用方法的简单处理
- 在存储过程中编写正确的事务处理代码(SQL Server 2000 & 2005)
- SQL Server在存储过程中编写事务处理代码的方法
- 在存储过程中编写正确的事务处理代码(SQL Server 2000 & 2005)
- SQLServer下 存储过程内 包含事务 及 返回处理是否成功
- 存储过程 务的概念 事务的特性 关于异常的处理 连接池 构JdbcUtil类
- JDBC中执行存储过程和对事务的处理
- SqlServer数据库的存储过程以及事务处理
- SQL Server存储过程中编写事务处理的方法小结
- SQL Server存储过程中编写事务处理的方法小结