赞
踩
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
目录
这是一篇关于SQL事务的文章
提示:以下是本篇文章正文内容,下面案例可供参考
MySQL 事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!
一般来说,事务是必须满足4个条件(ACID): Atomicity(原子性或不可分割性)、Consistency(一致性)、Isolation(隔离性或独立性)、Durability(持久性)
1,显式的开始一个事务
- start transaction
-
- 或者
-
- begin
2, 做保存点,一个事务中可以有多个保存点
savepoint 保存点名称
3, 提交事务,并使数据库中进行的所有修改成为永久性的
- commit
- 或者
- commit work
4,回滚结束用户的事务,并撤销正在进行的所有未提交的修改
- rollback
- 或者
- rollback work
5.删除一个事务的保存点,若没有指定保存点,执行该语句操作会抛错
release savepoint 保存点名称
6.将事务滚回标记点
rollback to 标记点
7.设置事务的隔离级别。InnoDB 存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ 和 SERIALIZABLE
set transaction
1.用 begin , rollback , commit 来实现事务处理。
2.用 set 来改变 MySQL 的自动提交模式。
- -- 关闭自动提交
- SET autocommit = OFF;
- SHOW VARIABLES LIKE 'autocommit';
- -- 开启事务 (一组事务)
- START TRANSACTION;
- UPDATE shop SET money = money + 500 WHERE NAME = 'A';
- UPDATE shop SET money = money + 10000 WHERE NAME = 'B';
-
- COMMIT; -- 提交事务 一旦提交就被持久化了
- ROLLBACK; -- 回滚
-
- SET autocommit = on; -- 恢复默认值
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。