【脚本编辑】每一千行UPDATE语句后插入一条COMMIT语句的编辑方法

提问:如何在一个具有几万行update语句的脚本中实现每1000条SQL语句后面输入一个“commit;”语句?

思考时间……

继续思考……

……



几种方法,抛砖在此,待玉到来。

1.如果喜欢使用Vi的朋友可以尝试如下命令
:%s/\v(.*\n){1000}/&commit;\r

2.如果是喜欢使用UE的朋友可以使用“宏”来完成(当然,Vi也可以使用录制宏的方法来实现)。

欢迎大家提供自己的妙招。


secooler
10.06.11

-- The End --

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/519536/viewspace-665103/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/519536/viewspace-665103/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL数据库管理,`COMMIT`是一个重要的事务控制命令,用于结束当前的事务并保存所有在此期间通过INSERT、UPDATE或DELETE操作所做出的数据更改。简单来说,当你在一个数据库会话了各种修改数据的操作,并希望将这些变化永久地保存到数据库时,就需要使用`COMMIT`命令。 ### `COMMIT`的基本工作原理 - **开始事务**:通常,开始一个新的事务不需要单独的命令,因为默认情况下,在连接到数据库后,新的操作都会在一个隐式的事务上下文。你可以通过显式调用`BEGIN TRANSACTION;`来明确开始一个事务。 - **执操作**:在事务内部,可以执各种SQL命令,如插入新记录、更新现有记录或删除记录等。 - **提交事务**:当所有的更改准备完毕并且想要将它们持久化到数据库时,就使用`COMMIT`命令。这会把事务内的所有更改应用到数据库,同时释放由事务持有的锁和其他资源。 - **回滚事务**:如果需要取消事务内的更改,可以使用`ROLLBACK`命令,它会撤销事务内所有的更改,将数据库状态恢复到事务开始前的状态。 ### 使用示例: 假设你想在一个表添加一些数据: ```sql BEGIN; INSERT INTO employees (name, position) VALUES ('Alice', 'Engineer'); UPDATE employees SET salary = 60000 WHERE name = 'Bob'; COMMIT; ``` 这条脚本首先开始了一个事务,然后添加了员工“Alice”的信息,并更新了名为“Bob”员工的薪水。最后,通过`COMMIT`命令保存了这些更改。 ### 相关问题: 1. **事务的概念是什么?** 事务是一组操作的集合,这些操作作为一个整体被提交或回滚。它保证了一致性和原子性,即要么全部成功,要么全部失败,不会留下部分操作的结果。 2. **为什么在大型系统频繁使用事务很重要?** 频繁使用事务能够确保数据一致性,避免并发操作导致的数据不一致问题,例如两个用户同时尝试修改同一数据的情况。 3. **`ROLLBACK`和`COMMIT`有什么区别?** - `COMMIT`:将当前事务的所有更改永久存储到数据库,并结束这个事务。 - `ROLLBACK`:撤销当前事务内的所有更改,并将数据库状态回退到事务开始前的状态。如果事务已经提交,则无法通过`ROLLBACK`恢复到提交前的状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值