欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

什么是事务?

程序员文章站 2022-05-15 09:35:11
事务的概念: 含义: 事务由单独单元的一个或者多个sql语句组成,在这个单元中,每个sql语句时相互依赖的。而整个单独单元作为一个不可分割的整体, 如果单元中某条sql语句一旦执行失败或者产生错误,整个单元将会回滚,也就是所有受到影响的数据将会返回到事务开始以前的状态;如果单元中的所有sql语句均执 ......

      事务的概念:

        含义

           事务由单独单元的一个或者多个sql语句组成,在这个单元中,每个sql语句时相互依赖的。而整个单独单元作为一个不可分割的整体,

           如果单元中某条sql语句一旦执行失败或者产生错误,整个单元将会回滚,也就是所有受到影响的数据将会返回到事务开始以前的状态;如果单元中的所有sql语句均执行成功,则事务被顺利执行。
        事务的属性:

            原子性:一个事务不可在分割,要么都执行要么都不执行。

            一致性:一个事务的执行会使数据从一个一致状态切换到另一个一致的状态。

            隔离性:一个事务的执行不受其他事物的干扰

            持久性: 一个事务一旦提交,则会永久的改变数据库的数据

        事务的创建:

           隐式事务:事务没有明显的开启和结束的标记

           显式事务:事务具有明显的开启和结束的标记 前提:必须先设置自动提交功能为禁用

              步骤1:开启事务
                set autocommit=0;
                start transaction;可选的
             步骤2:编写事务中的sql语句(select insert update delete)
                语句1
                语句2
             步骤3:结束事务
              commit;提交事务
              rollback;回滚事务

        数据库的隔离级别
           对于同时运行的多个事务,当这些事务访问数据库中的相同的数据时,如果没有采取必要的隔离机制就会产生并发问题:  脏读,不可重复读,幻读。
           数据库事务的隔离性:数据库系统必须具有隔离并发运行各个事务的能力,使他们不会相互影响避免并发问题。
          一个事物与其他事务隔离的程度称为隔离级别。隔离级别越高,,数据一致性就越好,但并发性就越弱。