1.事务的四大特性:一个事务具有的最主要的特性。一个设计良好的数据库能够为我们保证这四大特性。

1.1原子性:原子性是指事务是一个不可切割的工作单位,事务中的操作要么都发生要么都不发生。

1.2一致性:假设事务运行之前数据库是一个完整性的状态,那么事务结束后,不管事务是否运行成功,数据库仍然是一个完整性状态.

数据库的完整性状态:当一个数据库中的全部的数据都符合数据库中所定义的全部的约束,此时能够称数据库是一个完整性状态.

1.3隔离性:事务的隔离性是指多个用户并发訪问数据库时。一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间事务要隔离

1.4持久性:持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的。接下来即使数据库发生问题也不应该对其有不论什么影响。

2.隔离性:

将数据库设计成单线程的数据库,能够防止全部的线程安全问题,自然就保证了隔离性.可是假设数据库设计成这样,那么效率就会极其低下.

假设是两个线程并发改动,一定会互相捣乱,这时必须利用锁机制防止多个线程的并发改动

假设两个线程并发查询,没有线程安全问题

假设两个线程一个改动,一个查询……

脏读:一个事务读取到还有一个事务未提交的数据

不可反复读:在一个事务内读取表中的某一行数据,多次读取结果不同 — 行级别的问题

脏读

事务1:张三给李四转账100元

事务2:李四查看自己的账户

 t1:事务1:開始事务

 t2:事务1:张三给李四转账100元

 t3:事务2:開始事务

 t4:事务2:李四查看自己的账户,看到账户多出100元(脏读)

 t5:事务2:提交事务

 t6:事务1:回滚事务,回到转账之前的状态

不可反复读

事务1:酒店查看两次1048号房间状态

事务2:预订1048号房间

 t1:事务1:開始事务

 t2:事务1:查看1048号房间状态为空暇(第一次查询)

 t3:事务2:開始事务

 t4:事务2:预定1048号房间

 t5:事务2:提交事务

 t6:事务1:再次查看1048号房间状态为使用(第二次查询)

 t7:事务1:提交事务

对同一记录的两次查询结果不一致!

幻读

事务1:对酒店房间预订记录两次统计

事务2:加入一条预订房间记录

 t1:事务1:開始事务

 t2:事务1:统计预订记录100条

 t3:事务2:開始事务

 t4:事务2:加入一条预订房间记录

 t5:事务2:提交事务

 t6:事务1:再次统计预订记录为101记录

 t7:事务1:提交

  对同一表的两次查询不一致。

不可反复读和幻读的差别:

 不可反复读是读取到了还有一事务的更新。

 幻读是读取到了还有一事务的插入(MySQL中无法測试到幻读);

黑马day11 事务的四大特性的更多相关文章

  1. MySQL之事务的四大特性

    事务就是一组原子性的SQL查询,或者说一个独立的工作单元.如果数据库引擎能够成功地对数据应用该组查询的全部语句,那么久执行该组查询.如果其中任何一条语句因为崩溃或其他原因无法执行,那么所有语句都不会执 ...

  2. 事务的四大特性(ACID):

    事务的四大特性(ACID):    1.原子性(Atomicity): 事务中所有操作是不可再分割的原子单元.事务中所有操作要么都执行成功,要么都执行失败. 2.一致性(Consistency): 事 ...

  3. 数据库事务的四大特性以及事务的隔离级别(mysql)

      本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别. 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指 ...

  4. 数据库事务的四大特性以及事务的隔离级别-与-Spring事务传播机制&隔离级别

    数据库事务的四大特性以及事务的隔离级别   本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别. 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ ...

  5. 数据库中事务的四大特性(ACID)

    本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别. 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指事务 ...

  6. 数据库事务的四大特性以及4种事务的隔离级别-以及对应的5种JDBC事务隔离级别

    本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别. 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指事务 ...

  7. java面试题之----数据库事务的四大特性及隔离级别

    本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别. 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指事务 ...

  8. 事务的四大特性ACID

    ACID是指数据库事务的四大特性,是由Jim Gray在19世纪70年代后期提出的概念,1983年Andreas Reuter and Theo Härder创造了ACID这个缩略语用来描述这四大特性 ...

  9. DBMS事务的四大特性

    数据库事务的四大特性分别是:原子性.一致性.隔离性和持久性. 特性 说明 实现 一致性 在一个事务执行之前和执行之后数据库都必须处于一致性状态.假如数据库的状态满足所有的完整性约束,也可以说数据库是一 ...

随机推荐

  1. jenkins如何在一台机器上开启多个slave

    1.一台机器不是jenkins的master分支 2.另一台机器部署多个slave分支 3.部署多台slave分支的机器其实只需要在多个目录放置多个slave.jar就可以了,然后进行一些配置即可

  2. UNDO表空间损坏导致数据库无法OPEN

    在数据库undo表空间文件损坏.或者undo表空间文件缺失的情况下.无法打开数据库. 这两种情况都能够视为一种情况处理,解决方法一样. 场景:在23:10的时候新建一个undo表空间undotbs02 ...

  3. ubuntu中wifi显示被硬件禁用的解决方法

    本人使用的电脑是华硕X550C,安装了ubuntu16.04版本. 联网的时候显示“wifi已经通过硬件开关禁用”.按Fn+F2无法开启wifi.通过rfkill命令无法也无法开启wifi. 经过了解 ...

  4. Java ArrayList的模拟实现

    package test; import java.util.Arrays; import java.util.Collection; public class MyArrayList<E> ...

  5. 手游产品经理初探(四)从Buybutton谈玩家付费

    付费模块一直是游戏中最最重要的一块,那么今天我们从玩家的角度来解说哪种方式付费更迎合玩家的心理.我还是着重从我做的Casino类型游戏说起. 一般来说游戏界面喜欢把付费button放在界面最醒目的位置 ...

  6. [Unity3D]查看与设置游戏帧数FPS

    原地址:http://blog.sina.com.cn/s/blog_5b6cb9500101bta4.html 关于FPS,在PC端来说,游戏帧数跑得越高越好,FPS跑得越高游戏就越流畅,当然太高也 ...

  7. 小米miui系统怎么关闭文件管理里的热门视频和表情?

    小米miui系统怎么关闭文件管理里的热门视频和表情? 打开"文件管理"后,切换到"手机"选项卡. 然后,点击屏幕右上角的一排竖点. . 在弹出的菜单中点击&qu ...

  8. lodash escapeRegExp 转义正则特殊字符

    _.escapeRegExp([string='']) 转义RegExp 中特殊的字符 "^", "$", "\", ".&quo ...

  9. 提高PAAS安全性的一点尝试

    云服务已经成为现代人生活的一部分.手机中的照片会自己主动同步到云中:你的邮件内容保存在云中.办公软件执行在云中:你的健康数据会实时上传到云中.你每天的生活轨迹消耗的卡路里也会上传到云中:云服务也会逐渐 ...

  10. hdu3415 Max Sum of Max-K-sub-sequence 单调队列

    //hdu3415 Max Sum of Max-K-sub-sequence //单调队列 //首先想到了预处理出前缀和利用s[i] - s[j]表示(j,i]段的和 //之后的问题就转换成了求一个 ...