一、什么是事务

为什么要使用事务这个技术?现在很多软件都是多用户,多课程,多线程的,对于同一个表可能同时有很多人在用,为保持数据的一致性,所以提出了事务的概念。



1、查看数据库下面是否支持事务(InnoDB支持)?

show engines;




2、查看mysql当前默认的存储引擎?

show variables like '%storage_engine%';





3、查看某张表的存储引擎?


show create table test;




4、对于表的存储结构的修改?


建立InnoDB表:Create table ... type=InnoDB;Alter table table_name type=InnoDB;


二、实例:

1、创建一个数据库bank

create table account(
aid int not null,
accname varchar(20) not null,
accmoney decimal(10,2) not null,
primary key(aid))engine = innodb default charset = gbk;



2、向account表中插入两条数据

insert into account values(1,'A',4000);
insert into account values(2,'B',2000);



3、开启表的事务

start transaction;



4、把数据设置为主动提交

commit;
set autocommit = 0;



5、执行下面一条语句

<pre name="code" class="sql">update account set accmoney = accmoney - 1000 where aid = 1;
update account set accmoney = accmoney + 1000 where aid = 2;



6、打开新的MySQL命令窗口查看account表

select * from account;

会发现数据并没有发生改变,因为上面修改了指令,数据库并没有发出修改指令;


7、在原有的窗口中查询就会发现数据已经改变

select * from account;

8、进行commit实物提交

commit;


9、在另外的客户端中查看数据就会发现数据已经改变

select * from account;


三、事务回滚和还原点

1、事务的回滚

回到事务发生之前的数据状态。通过rollback。

补充:commit and chain;表示提交事务之后重新开启了新的事务。 

            rollback and release;表示回滚之后断开和客户的链接。


2、还原点(实例)

set autocommit = 0;
insert into account values(3,'C',3000);
savepoint a1;
insert into account values(4,'D',3000);
savepoint a2;
insert into account values(5,'E',3000);
savepoint a3;



查看数据库信息

select * from account;

就会看到你插入的数据


如果你想回滚到某一状态只需rollback调用一下就行;

如:回到savepoint a1的状态

rollback to savepoint a1;



然后再执行查询语句

就会看到表中就有一条新加的数据。


四、事务总结

事务应该具有4个属性:

原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。

原子性(atomicity):一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。

一致性(consistency):事务必须是使数据库从一个一致性状态变到另一个一致性的状态。一致性与原子性是密切相关的。

隔离性(isolation):一个事务的执行不能被其他事务干扰,即一个事务内部操作及使用的数据对并发的其他事务隔离的,并发执行的各个事务之间不能相互干扰。

持久性(durability):持久性也成永久性。只一个事务一旦提交,它对数据库中数据的改变就应该是永久性的改变。接下来的其他操作或故障不应该对其有任何影响。