1. 事务处理
并非所有引擎都支持事务处理。MyISAM和InnoDB是两种最常使用的引擎,前者不支持明确的事务处理管理,而后者支持。
事务处理可以用来维护数据库的完整性,它保证成批的MySQL操作要么完全执行,要么完全不执行。
事务transaction:指一组SQL语句;
回退rollback:指撤销指定SQL语句的过程;
提交commit:指将未存储的SQL语句结果写入数据库表;
保留点savepoint:指事务处理中设置的临时占位符,可以对它分步回退(与回退整个事务处理不同)。
控制事务处理:
MySQL使用下面的语句来标识事务的开始:
START TRANSACTION
使用ROLLBACK:
MySQL的ROLLBACK命令用来回退(撤销)MySQL语句。
SELECT * FROM ordertotals;
START TRANSACTION;
DELETE FROM ordertotals;
SELECT * FROM ordertotals;
ROLLBACK;
SELECT * FROM ordertotals;
这里是先显示了一个表(与事务无关)。用START TRANSACTION来开始事务。用ROLLBACK来回退事务,中间的SQL语句是这个事务的一组SQL命令。
ROLLBACK只能在一个事务处理内使用(在执行一条START TRANSACTION命令之后)。
哪些事务可以回退?事务处理用来管理INSERT、UPDATE和DELETE语句,不能回退SELECT语句&#x