事务处理
事务处理 一、事务四特性(ACID) 1、原子性:一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。也就是说如果事务中的某一步出错,所有对数据进行的 2、一致性:事务必须是使数据库从一个状态变到另一个状态。总的状态要一致。 3、隔离性:一个事务的执行不会被其他事务所干扰。 4、持久性:一个事务一旦提交,它对数据改动将是持久性的,其他操作和故障不应使其数据丢失。 二、mysql数据库事务 1、事务的语句 使用START TRANSACTION或者BEGIN来开启一个新事务。 使用COMMIT来提交一个事务,使其操作产生持久性的影响。 使用ROOLBACK来撤回这次事务,取消其产生的影响。 使用SET autocommit来设置是否自动提交事务。 2、默认事务 mysql默认使用autocommit,这意味着每一个语句都是原子性的,其效果相当于把该语句环绕一个begin和commit语句的事务,并且不能使用rollback语句。当该语句执行过程中出现错误时,该语句则被ROOLBACK。 3、事务隔离级别 读未提交:为事务之间提供最小的保护,它使用了特定的锁定策略,允许一个事务在不等待另一个事务结束的情况下继续执行。这种性能的提升降低了一致性,导致了脏读(读取其他事务未提交的数据)等出现。一般在只执行查询操作的情况下使用。 读已提交:采用某种锁定策略