一个SQL server的事务存储
-- =============================================
-- Author: Evan
-- Create date: 2018年6月14日 16点27分
-- Description: 冻结BOL不允许GI,或取消冻结
-- =============================================
ALTER PROCEDURE [dbo].[SP_FRU_FreezeGIByBOLorCancle]
(
@BOL NVARCHAR() ,
@UpdateBy NVARCHAR() ,
@Flag INT --0表示冻结,1表示取消,2查询未GI的BOL的冻结信息
)
AS
BEGIN
--开始事务
BEGIN TRANSACTION
--设置一个存储报错代码的变量
DECLARE @errorSum INT
SET @errorSum =
--在每一条涉及到数据变动的语句后都累加一次报错代码
IF ( @Flag = )
BEGIN
UPDATE ddd WITH ( ROWLOCK )
SET ddd.STATE = ,
ddd.UpdateBy = @UpdateBy ,
ddd.UpdateDate = GETDATE()
FROM dbo.Fn_Split(@BOL, '/') fn
LEFT JOIN dbo.D_ControlGIByBOL ddd ON fn.value = ddd.BOL
WHERE ddd.ID IS NOT NULL;
SET @errorSum += @@ERROR;
INSERT INTO dbo.D_ControlGIByBOL
( ID ,
BOL ,
State ,
CreateBy ,
CreateDate
)
SELECT NEWID() id ,
fn.value ,
state ,
@UpdateBy createby ,
GETDATE() createdate
FROM dbo.Fn_Split(@BOL, '/') fn
LEFT JOIN dbo.D_ControlGIByBOL ddd ON fn.value = ddd.BOL
WHERE ddd.ID IS NULL;
SET @errorSum += @@ERROR; END
IF ( @Flag = )
BEGIN
--------------------------------------------------取消冻结
UPDATE D_ControlGIByBOL WITH ( ROWLOCK )
SET State = ,
UpdateBy = @UpdateBy ,
UpdateDate = GETDATE()
WHERE BOL IN ( SELECT DISTINCT
fn.value
FROM dbo.Fn_Split(@BOL, '/') fn )
SET @errorSum += @@ERROR;
END
--报错代码不为0表示在执行上述sql时出现错误,回滚事务,撤销所有更改
IF ( @errorSum <> )
BEGIN
SELECT '执行错误:' + CAST(@errorSum AS VARCHAR());
ROLLBACK TRANSACTION
END
ELSE
--报错代码为0表示无报错信息,可以执行更改操作
BEGIN
IF ( @Flag = )
BEGIN
SELECT '批量冻结成功';
END
IF ( @Flag = )
BEGIN
SELECT '批量取消冻结成功';
END
IF ( @Flag = )
BEGIN
SELECT ddd.BOL,ddd.CreateBy,ddd.CreateDate,ddd.UpdateBy,ddd.UpdateDate,
CASE WHEN ddd.State= THEN '冻结'
WHEN ddd.State= THEN '未冻结'
ELSE '异常'
END as State
FROM dbo.D_ControlGIByBOL ddd
WHERE ddd.State =
ORDER BY CreateDate DESC
END
COMMIT TRANSACTION
END
END
一个SQL server的事务存储的更多相关文章
- 第十七周翻译-SQL Server中事务日志管理的阶梯,级别5:以完全恢复模式管理日志
SQL Server中事务日志管理的阶梯,级别5:以完全恢复模式管理日志 作者:Tony Davis,2012/01/27 翻译:赖慧芳 译文: 该系列 本文是Stairway系列的一部分:SQL ...
- SQL Server中事务日志管理的步骤,第5级:完全恢复模式管理日志(译)
SQL Server中事务日志管理的步骤,第5级:完全恢复模式管理日志 作者:Tony Davis,2012/01/27 系列 本文是进阶系列的一部分:SQL Server中事务日志管理的步骤 当事情 ...
- SQL Server中事务、锁定和阻塞
事务是什么 在SQL Server中事务是构成一个工作逻辑单元的一系列任务,也就说多个任务放在一起执行,这些任务要么全部执行成功,要么全部执行失败. 通过事务我们可以保证数据的完整性,例如:用户A给用 ...
- SQL Server提高事务复制效率优化(一)总体概述
随着公司业务的发展,数据量增长迅速,在解决Scale Out的同时,还要考虑到主从的复制延迟问题,尽量降到1s以内满足线上业务,如果不调整,SQL Server默认的配置可能平均要3s左右.生产的 ...
- SQL SERVER 分布式事务(DTC)
BEGIN DISTRIBUTED TRANSACTION指定一个由 Microsoft 分布式事务处理协调器 (MS DTC) 管理的 Transact-SQL 分布式事务的起始. 语法BEGIN ...
- 如何读懂SQL Server的事务日志
简介 本文将介绍SQL Server的事务日志中记录了哪一些信息,如何来读懂这些事务日志中信息.首先介绍一个微软没有公开的函数fn_dblog,在文章的接下来的部分主要用到这个函数来读取事务日志. f ...
- SQL Server 2016 查询存储性能优化小结
SQL Server 2016已经发布了有半年多,相信还有很多小伙伴还没有开始使用,今天我们来谈谈SQL Server 2016 查询存储性能优化,希望大家能够喜欢 作为一个DBA,排除SQL Ser ...
- SQL Server 之 事务与隔离级别实例讲解
SQL Server 之 事务与隔离级别实例讲解 SQL Server 实现了6个隔离级别来防止并发情况下,类似企图并发的访问或修改同一数据时问题的发生.本文将带你体验全部6个隔离级别.正如你接下来将 ...
- Step2:SQL Server 复制事务发布
一.背景 在复制的运用场景中,事务发布是使用最为广泛的,我遇到这样一个场景:在Task数据库中有Basic与Group两个表,需要提供这两个表的部分字段给其它程序读取放入缓存,程序需要比较及时的获取到 ...
随机推荐
- 【hdu4570】Multi-bit Trie 区间DP
标签: 区间dp hdu4570 http://acm.hdu.edu.cn/showproblem.php?pid=4570 题意:这题题意理解变态的.转自大神博客: 这题题意确实有点难懂,起码对于 ...
- skb详细解析【转】
skb详细解析[转] 摘自:http://blog.chinaunix.net/uid-30035229-id-4883992.html 在自己的模块发送函数中,需要对skb进行重新构造 ...
- lua调用c函数
参考:http://blog.163.com/madahah@126/blog/static/170499225201121504936823/ 1.编辑C程序 vim luac.c #include ...
- debian linux中文桌面系统安装
一.基本系统安装 1 .安装光盘:可以到http://debian.cn99.com去下载ISO,我是之前从官方网站下载的.一只载第一张光盘即可.用NERO烧录成光碟. 2.将安装光盘放驱,并在BIO ...
- 如何快速编写大项目的Makefile文件
在构建C++的后台服务时,经常需要自己来编写makefile文件,而如果没有合适的方法或模板时,编写makefile文件是一件很费时费力的事情.因此,为了帮助程序员高效准确的编写makefile文件, ...
- 2010辽宁省赛G(佩尔方程)
#include <iostream> #include <stdio.h> #include <string.h> #include <algorithm& ...
- 3dmax沿立方体边扩展出面
这个做法有问题,接缝问题处理起来很麻烦,立方体与平面的拼接基本就做不到 做建筑时,一般先做墙,然后通过墙扩展出地表,这么做可以保证墙和地表是一体的,避免产生缝隙 1 新建2个Cube 2 转换为可编辑 ...
- 三、python的基本类型
一.number 整数 int 浮点数 float 1.type()查看类型 >>> type(1) <class 'int'> >>> type(1. ...
- Programming Ruby 阅读笔记
在Ruby中,通过调用构造函数(constructor)来创建对象 song1=Song.new("Ruby") Ruby对单引号串处理的很少,除了极少的一些例外,键入到字符串字面 ...
- Luogu P3166 [CQOI2014]数三角形 组合数学
好题鸭.. 不好直接求三角形个数,那就用全集-补集,转化为求三点共线的数量. 具体求法是求出水平共线数量与竖直共线数量和斜线共线数量. 用排列组合的知识可知为水平和竖直的为$C_n^3$与$C_m^ ...