在生产环境中安全执行更新删除SQL脚本的技巧
2014-06-03 21:13
357 查看
今天在生产环境上解决问题,由于广发银行的管理制度是开发公司是不允许确生产环境的,所以我们只能把要更新的语句发给运营中心,由运营中心的投产人员执行,我们则在旁边看着;在他执行的时候发现了一个很有趣的技巧,现在分享出来。
我们知道每一次在生产环境中执行中执行更新删除语句的时候都要格外小心,要做好数据备份,但是即便这样对于一个做了分库分表设计,有十几个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保证了这个事务提交成功。
我们知道每一次在生产环境中执行中执行更新删除语句的时候都要格外小心,要做好数据备份,但是即便这样对于一个做了分库分表设计,有十几个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保证了这个事务提交成功。
相关文章推荐
- Linux Shell脚本生产环境下安全地删除文件
- Scripts:从shared_pool中创建并删除profile的脚本(注意,此脚本危险比较高,生产环境不要使用)flush_sql10p.sql
- 步步为营VS 2008 + .NET 3.5(9) - DLINQ(LINQ to SQL)之执行SQL语句的添加、查询、更新和删除
- DLINQ(LINQ to SQL)之执行SQL语句的添加、查询、更新和删除
- Oracle导入SQL脚本执行 scott 用户下的表删除了
- mysql sql技巧: 子查询改为连接查询&&涉及多个表的删除和更新
- PowerDesigner 16 生产SQL语句 无法更新或删除属性。“某某”的属性 MS_Description不存在解决研究
- 步步为营VS 2008 + .NET 3.5(9) - DLINQ(LINQ to SQL)之执行SQL语句的添加、查询、更新和删除
- 网络安全架构师必修课)生产环境下的 wireshark 数据包捕获,过滤,分析技巧与实战
- Oracle数据库案例整理-执行Oracle脚本失败或异常-SQL命令中字符串参数使用双引号导致更新数据库表信息失败
- 生产环境Mysql数据库备份脚本,Linux下网站数据定期自动备份与删除脚本,Windows下备份网站目录和数据库
- 如何在java环境下执行sql脚本文件
- shell脚本操作mysql数据库,使用mysql的-e参数可以执行各种sql的(创建,删除,增,删,改、查)等各种操作
- oracle 执行sql文件脚本,批量插入或批量更新
- MySQL Workbench 执行更新或删除操作时出现 1175错误 安全更新限制
- 步步为营VS 2008 + .NET 3.5(9) - DLINQ(LINQ to SQL)之执行SQL语句的添加、查询、更新和删除
- 9、步步为营VS 2008 + .NET 3.5(9) - DLINQ(LINQ to SQL)之执行SQL语句的添加、查询、更新和删除
- CodeSmith实用技巧(十二):自动执行SQL脚本
- shell脚本操作mysql数据库,使用mysql的-e参数可以执行各种sql的(创建,删除,增,删,改、查)等各种操作
- shell脚本操作mysql数据库,使用mysql的-e参数可以执行各种sql的(创建,删除,增,删,改、查)等各种操作