数据库-基础

@数据库

数据库

1.事务

事务就是指满足ACID的一系列操作,可以使用 commit提交一个事务,也可以使用rollback回滚

2.数据库事务的四个特性ACID

原子性:
事务的最小单位,不允许再被分割。意味着执行的话要么一起成功,要么一起失败。如果事务在执行的过程中发生错误,则回滚到事务执行前最初状态
一致性:
数据库在事务执行前后是保持一致的
隔离性:
一个事务在做出修改时在被提交之前对其他事务是不可见的
持久性:
一旦事务提交以后,做出的修改就被永久的保存在数据库中,并不会被回滚

3.事务的隔离级别

在讲事务隔离级别之前必须先看看为什么会出现隔离级别这种概念
上面讲到了事务必须是满足ACID四个特性的
在并发的情况下,事务的隔离性很难满足,因此会发生一系列并发一致性问题
参考文章-讲的超级好COPY

并发导致的问题
丢失修改
当T1和T2修改同一个数据的时候,T1先执行,T2后执行,当T1执行var=50以后,T2又执行var=100,将T1的执行结果覆盖。
在这里插入图片描述

脏读
当T1对数据进行修改后,这个时候T2读取了T1修改后的数据,但随后T1又执行了回滚操作,那么这个时候T2读出来的就是脏数据
在这里插入图片描述

不可重复读
(在一个事务范围内操作读取两次同一数据获取的内容不一样)
T2 读取一个数据,T1 对该数据做了修改。如果 T2 再次读取这个数据,此时读取的结果和第一次读取的结果不同。
在这里插入图片描述
幻影读
T1 读取某个范围的数据,T2 在这个范围内插入新的数据,T1 再次读取这个范围的数据,此时读取的结果和和第一次读取的结果不同。
在这里插入图片描述

不可重复读和幻影读
不可重复读重点在update,而幻影读重点在于insert和delete

说完并发情况下可能出现的问题后,再讲解下事务的隔离级别

隔离级别
Read Uncommitted 未提交读
事务中的修改哪怕没有提交对其他事务也是可见的。
最低的隔离级别,可能会导致脏读、不可重复读、幻影读
Read Committed 提交读
允许读取并发事务已经提交的数据
可以阻止脏读、但是幻读和不可重复读还是有可能发生
Repeatable Read 可重复读
保证在同一个事务中多次读取同样数据的结果是一样的。
可以阻止脏读和不可重复读,幻读可能会发生
Serializable 可串行化
最高隔离级别,让各个事务都逐个执行,完全遵循acid的隔离级别。该级别可以防止脏读、不可重复读以及幻读。但是严重的影响了程序的性能

MYSQL默认采用REPEATABLE_READ级别,ORACLE默认采用READ_COMMITTED隔离级别

== spring有关事务的接口及其传播性 :==

https://mp.weixin.qq.com/s?__biz=MzU4NDQ4MzU5OA==&mid=2247483994&idx=1&sn=770af2a712c9a7efe2391bd23dddeea2&chksm=fd98543bcaefdd2d24f433f412e7046ebddf8791cbb0f45693192a6f6312ac1e1679aa783ad4#rd

删除文本

引用文本

插入链接与图片

链接: link.

图片: Alt

带尺寸的图片: Alt

当然,我们为了让用户更加便捷,我们增加了图片拖拽功能。

如何插入一段漂亮的代码片

博客设置页面,选择一款你喜欢的代码片高亮样式,下面展示同样高亮的 代码片.

// An highlighted block
var foo = 'bar';

生成一个适合你的列表

  • 项目
    • 项目
      • 项目
  1. 项目1
  2. 项目2
  3. 项目3
  • 计划任务
  • 完成任务

创建一个表格

一个简单的表格是这么创建的:

项目Value
电脑$1600
手机$12
导管$1

设定内容居中、居左、居右

使用:---------:居中
使用:----------居左
使用----------:居右

第一列第二列第三列
第一列文本居中第二列文本居右第三列文本居左

SmartyPants

SmartyPants将ASCII标点字符转换为“智能”印刷标点HTML实体。例如:

TYPEASCIIHTML
Single backticks'Isn't this fun?'‘Isn’t this fun?’
Quotes"Isn't this fun?"“Isn’t this fun?”
Dashes-- is en-dash, --- is em-dash– is en-dash, — is em-dash

创建一个自定义列表

Markdown
Text-to- HTML conversion tool
Authors
John
Luke

如何创建一个注脚

一个具有注脚的文本。1

注释也是必不可少的

Markdown将文本转换为 HTML

KaTeX数学公式

您可以使用渲染LaTeX数学表达式 KaTeX:

Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n1)!nN 是通过欧拉积分

Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t   . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=0tz1etdt.

你可以找到更多关于的信息 LaTeX 数学表达式here.

新的甘特图功能,丰富你的文章

Mon 06 Mon 13 Mon 20 已完成 进行中 计划一 计划二 现有任务 Adding GANTT diagram functionality to mermaid
  • 关于 甘特图 语法,参考 这儿,

UML 图表

可以使用UML图表进行渲染。 Mermaid. 例如下面产生的一个序列图::

张三 李四 王五 你好!李四, 最近怎么样? 你最近怎么样,王五? 我很好,谢谢! 我很好,谢谢! 李四想了很长时间, 文字太长了 不适合放在一行. 打量着王五... 很好... 王五, 你怎么样? 张三 李四 王五

这将产生一个流程图。:

链接
长方形
圆角长方形
菱形
  • 关于 Mermaid 语法,参考 这儿,

FLowchart流程图

我们依旧会支持flowchart的流程图:

Created with Raphaël 2.2.0 开始 我的操作 确认? 结束 yes no
  • 关于 Flowchart流程图 语法,参考 这儿.

导出与导入

导出

如果你想尝试使用此编辑器, 你可以在此篇文章任意编辑。当你完成了一篇文章的写作, 在上方工具栏找到 文章导出 ,生成一个.md文件或者.html文件进行本地保存。

导入

如果你想加载一篇你写过的.md文件或者.html文件,在上方工具栏可以选择导入功能进行对应扩展名的文件导入,
继续你的创作。


  1. 注脚的解释 ↩︎

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值