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