事务的概念:
含义:
事务由单独单元的一个或者多个sql语句组成,在这个单元中,每个sql语句时相互依赖的。而整个单独单元作为一个不可分割的整体,
如果单元中某条sql语句一旦执行失败或者产生错误,整个单元将会回滚,也就是所有受到影响的数据将会返回到事务开始以前的状态;如果单元中的所有sql语句均执行成功,则事务被顺利执行。
事务的属性:
原子性:一个事务不可在分割,要么都执行要么都不执行。
一致性:一个事务的执行会使数据从一个一致状态切换到另一个一致的状态。
隔离性:一个事务的执行不受其他事物的干扰
持久性: 一个事务一旦提交,则会永久的改变数据库的数据
事务的创建:
隐式事务:事务没有明显的开启和结束的标记
显式事务:事务具有明显的开启和结束的标记 前提:必须先设置自动提交功能为禁用
步骤1:开启事务
set autocommit=0;
start transaction;可选的
步骤2:编写事务中的sql语句(select insert update delete)
语句1
语句2
步骤3:结束事务
commit;提交事务
rollback;回滚事务
数据库的隔离级别
对于同时运行的多个事务,当这些事务访问数据库中的相同的数据时,如果没有采取必要的隔离机制就会产生并发问题: 脏读,不可重复读,幻读。
数据库事务的隔离性:数据库系统必须具有隔离并发运行各个事务的能力,使他们不会相互影响避免并发问题。
一个事物与其他事务隔离的程度称为隔离级别。隔离级别越高,,数据一致性就越好,但并发性就越弱。
数据库事务的隔离性:数据库系统必须具有隔离并发运行各个事务的能力,使他们不会相互影响避免并发问题。
一个事物与其他事务隔离的程度称为隔离级别。隔离级别越高,,数据一致性就越好,但并发性就越弱。