mysql的事务

发布时间:2个月前热度: 151 ℃评论数:

     最近在找工作,有一家公司要做一些小测试题,有一题问到:数据库中什么是事务?像我们平时一股劲的写代码,虽然说数据库事务在这个概念都懂,但是如果真的要写出来,还是写的不太官方,今天,结合网上的一些对事务讲解的资料,就来总结一下!

     

     一.什么是事务
     事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消。也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做。
    事务的结束有两种,当事务中的所以步骤全部成功执行时,事务提交。如果其中一个步骤失败,将发生回滚操作,撤消之前到事务开始时的所以操作。


    二.事务的 ACID(特性)
事务具有四个特征:原子性( Atomicity )、一致性( Consistency )、隔离性( Isolation )和持续性( Durability )。这四个特性简称为 ACID 特性。


   1 、原子性
   事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
   2 、一致性
   事 务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。
   3 、隔离性
   一个事务的执行不能其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
   4 、持续性
  也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。

数据库系统必须维护事务的以下特性 ( 简称 ACID) :

   原子性 (Atomicity)
  一致性 (Consistency)
  隔离性 (Isolation)
  持久性 (Durability)
  原子性 (Atomicity)

事务中的所有操作要么全部执行,要么都不执行;如果事务没有原子性的保证,那么在发生系统故障的情况下,数据库就有可能处于不一致状态。

数据库,.事务

  栏目导航

  1. 杂谈
  2. PHP
  3. 建站
  4. MySql
  5. Laravel
  6. ThinkPHP
  7. 面试

  手机扫码访问