MySQL事务管理的介绍(附示例)

不言
Lepaskan: 2019-02-27 11:59:20
ke hadapan
2571 orang telah melayarinya

本篇文章给大家带来的内容是关于MySQL事务管理的介绍(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

事务处理用来维护数据库等完整性,保证mysql操作要么成功,要么失败(myisam不支持事务)

1、关键词

  1. 事务(transaction)指一组SQL语句;

  2. 回退(rollback)指撤销指定SQL语句的过程;

  3. 提交(commit)指将未存储的SQL语句结果写入数据库表;

  4. 保留点(savepoint)指事务处理中设置的临时占位符(place-holder),你可以对它发布回退(与回退整个事务处理不同)。

2、使用rollback

select * from orderitems;
START TRANSACTION;
DELETE FROM orderitems;
select * from orderitems;
ROLLBACK;
select * from orderitems;
Salin selepas log masuk

3、使用commit

START TRANSACTION;
DELETE FROM orderitems where order_num = 20010;
DELETE FROM orders WHERE order_num = 20010;
COMMIT
Salin selepas log masuk

假设第二条删除失败,回滚,撤销事务处理块内的语句

4、使用保留点

复杂的事务处理可能需要部分提交或回退。  
为了支持回退部分事务处理,必须能在事务处理块中合适的位置放 置占位符。这样,如果需要回退,可以回退到某个占位符。
这些占位符称为保留点。为了创建占位符,可如下使用SAVEPOINT

创建保留点

SAVEPOINT delete1
Salin selepas log masuk

回退到保留点

ROLLBACK TO delete1
Salin selepas log masuk

tips

保留点越多越好,方便灵活使用,but没必要到就算来哈!凡事适可而止  
释放保留点

  1. 保留点在事务处理完成(执行一条ROLLBACK或 COMMIT)后自动释放

  2. release savepoint delete1明确释放保留点

5、更改默认到提交行为

mysql是自动提交所有更改。
不自动提交更改

set autocommit = 0;
Salin selepas log masuk

Atas ialah kandungan terperinci MySQL事务管理的介绍(附示例). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:segmentfault.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan