事务是由一组SQL语句构成的,它由一个用户输入,并以修改成持久的或者滚到原来状态而终结。在mysql中,当一个回话开始时,系统变量autocommit值为1,即自动提交功能是打开的,当用户每执行一条SQL语句后,该语句对数据库的修改就立即被提交成为持久性修改保存到磁盘上,一个事务也就结束了。因此,用户必须关闭自动提交,事务才能由多条SQL语句组成,使用如下语句:
set @@autocommit=0;
下面几个语句说明了有关事务的处理过程:
1.start transaction;开始事务
2.updata....
3.delete...
4.savepoint s1;设置一个保存点
5.delete...
6.rollback work to savepoint s1;将事务回滚到保存点s1,这时第五行的修改被撤销了
7.insert...
8.commit work;提交并结束事务