数据库事务基本特性,隔离级别与事务传播性

事务是区分文件存储系统与Nosql数据库重要特性之一,其存在的意义就是为了保证正确执行crud操作,如何才算正确操作?于是引出了事务需要保证4个特性ACID。

事务的基本特性

  • 原子性(atomicity):事务各项操作,要么全部成功要么全部失败,及任何一个操作失败,整个事务就会失败。
  • 一致性(consistency):事务结束后系统状态是一致的。(例如:银行转账,转账最终总是是一致的)
  • 隔离性(islatioin):并发执行彼此事务无法看到对方状态。
  • 持久性(isolation):事务完成后数据将会被持久化,即使发生灾难性的失败。

在高并发情况下,要完全保证ACID是非常困难的,除非把所有的事务操作串行化执行,但是性能将会大大降低,所有数据库设计了4中隔离级别,提供给用户争对不同中情况,基于业务作出选择:

隔离级别脏读 (Dirty Read)不可重复读(NonRepeatable Read)幻读(Phantom Read)
未提交读(Read uncommitted)可能可能可能
已提交读(Read Committed)不可能可能可能
可重复读(Repeatable)不可能不可能可能
串行化(Serializable)不可能不可能不可能
  • 脏读:一个事务读取到另外一个事务未提交的更新数据
  • 不可重复读:在同一个事务中,多次读取通一数据返回的结果有所不同,后续读取可以读取到另一事务已提交的更新数据,相反,“可重复读”在同一事物中多次读取数据时,能够保证所读取到的数据一致,也就是后续读取不能读取到另一个事务已提交的更新数据。
  • 幻读:查询表中一条数据如果不存在就插入一条,并发时候确发现,数据库里存在两条一样的数据,这就是幻读问题(一般使用幂等性保证)

mysql数据库,默认隔离级别为:可重复读(Repeatable)

事务传播机制

类别 事务传播类型说明
支持当前事务PROPAGATION_REQUIRED(必须的)如果当前没有事务,就新建一个事务,如果已经存在一个事务中,就加入到这个事务中,这是最常见的选择
PROPAGATION_SUPPORTS(支持)支持当前事务,如果当前没有事务,就以非事务方式执行
PROPAGATION_MANDATORY(强制)使用当前事务,如果当前没有事务,就抛出异常
不支持当前事务PROPAGATION_REQUIRED_NEW(隔离)新建事务,如果当前事务不存在,就把当前事务挂起
PROPAGATION_NOT_SUPPORTS(不支持)以非事务方式执行,如果当前事务存在,就把当前事务挂起
PROPAGATION_NEVER(强制非事务)以非事务方式执行,如果当前存在事务就抛出异常
嵌套事务PROPAGATION_NESRWD(嵌套事务)如果当前存在事务,则在嵌套事务内执行,如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作
  • 挂起:产生一个新的连接,建一个新的事务
  • 什么操作属于同一事务?
新建连接
  conn = new Connention()
  conn.setAutoCommit(false)
// 增,删,改,查
conn.commit 或者 conn.rollback 或 conn.close()
之间都属于同一事物
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用 JavaScript 编写的记忆游戏(附源代码)   项目:JavaScript 记忆游戏(附源代码) 记忆检查游戏是一个使用 HTML5、CSS 和 JavaScript 开发的简单项目。这个游戏是关于测试你的短期 记忆技能。玩这个游戏 时,一系列图像会出现在一个盒子形状的区域中 。玩家必须找到两个相同的图像并单击它们以使它们消失。 如何运行游戏? 记忆游戏项目仅包含 HTML、CSS 和 JavaScript。谈到此游戏的功能,用户必须单击两个相同的图像才能使它们消失。 点击卡片或按下键盘键,通过 2 乘 2 旋转来重建鸟儿对,并发现隐藏在下面的图像! 如果翻开的牌面相同(一对),您就赢了,并且该对牌将从游戏中消失! 否则,卡片会自动翻面朝下,您需要重新尝试! 该游戏包含大量的 javascript 以确保游戏正常运行。 如何运行该项目? 要运行此游戏,您不需要任何类型的本地服务器,但需要浏览器。我们建议您使用现代浏览器,如 Google Chrome 和 Mozilla Firefox, 以获得更好、更优化的游戏体验。要玩游戏,首先,通过单击 memorygame-index.html 文件在浏览器中打开游戏。 演示: 该项目为国外大神项目,可以作为毕业设计的项目,也可以作为大作业项目,不用担心代码重复,设计重复等,如果需要对项目进行修改,需要具备一定基础知识。 注意:如果装有360等杀毒软件,可能会出现误报的情况,源码本身并无病毒,使用源码时可以关闭360,或者添加信任。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值