博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在生产环境中安全执行更新删除SQL脚本的技巧
阅读量:6612 次
发布时间:2019-06-24

本文共 786 字,大约阅读时间需要 2 分钟。

今天在生产环境上解决问题,由于广发银行的管理制度是开发公司是不允许确生产环境的,所以我们只能把要更新的语句发给运营中心,由运营中心的投产人员执行,我们则在旁边看着;在他执行的时候发现了一个很有趣的技巧,现在分享出来。

我们知道每一次在生产环境中执行中执行更新删除语句的时候都要格外小心,要做好数据备份,但是即便这样对于一个做了分库分表设计,有十几个G的库来说更新一句SQL后发现忘记写WHERE语句或是语句写错了,恢复备份的成本都是相当高的。

我注意到运营中心的人在拿到我的SQL语句后,把它放到MSSMS中后在前面加上了BEGIN TRAN,最后加上了—COMMIT,然后就放心的执行了,玄机就在这里了。这么说有点抽象,我举个例子:

假设我要更新生产中的一个叫做UserName的人的名字,原来的名字叫许小鹏,要改成的名字叫许鹏,这样的话我就写了一条SQL语句如下

UPDATE dbo.SEC_Users SET [UserName]='许鹏'

如果直接执行的话,可能悲剧就发生了,因为我忘记写WHERE语句了。但是如果更成如下:

BEGIN TRAN

UPDATE dbo.SEC_Users SET [UserName]='许鹏'

--COMMIT

这样的话执行一下,发现影响了很多行,而不是期望中的影响了一行,所以这个时候我们还是有机会回滚的,如果我们写的没有问题的话,如下

BEGIN TRAN

UPDATE dbo.SEC_Users SET [UserName]='许鹏' WHERE [UserName]='许小鹏'

--COMMIT

这样的话执行一下,发现影响了很1行,这是在我们期望中的,所以我们继续执行下面的COMMIT保证了这个事务提交成功。

转载于:https://www.cnblogs.com/biyusoft/p/3766477.html

你可能感兴趣的文章
UVa1366 Martian Mining
查看>>
指定子设备号创建字符设备
查看>>
debugs
查看>>
C,C++经典(程序、错误程序)
查看>>
ubuntu centos debina
查看>>
windows wim
查看>>
python,re模块正则
查看>>
Altera发布基于FPGA的1080p/30fps视频分析解决方案
查看>>
实验三
查看>>
[转载]使用兼容ie6 ie7 ie8 FF的text-overflow:ellips
查看>>
数据持久化(一)--NSKeyedArchiver
查看>>
Objective-C的setter和getter
查看>>
python数据类型之 元祖、列表字典
查看>>
读周国平作品有感
查看>>
极光消息推送服务器端开发实现推送(上)
查看>>
实现日期比较
查看>>
CMake平台判断
查看>>
NO11 SSH故障排查思路和netstat命令
查看>>
P1060 开心的金明(洛谷,动态规划递推,01背包轻微变形题)
查看>>
逆波兰表达式的递归计算
查看>>