本文主要是介绍2021-09-24 数据库总结,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
数据库总结
一.存储引擎
MylSAM和InnoDB两种存储引擎,MySql中常用的存储引擎为InnoDB。
MylSAM和InnoDB的主要区别:
- InnoDB支持事务
- InnoDB是聚集索引,MylSAM是非聚集索引。
1)聚集索引的文件存放在主键索引的叶子节点上。因此,InnoDB必须要有主键,通过主键索引的效率很高。但是辅助索引需要两次查询,先查询到主键,再通过主键查询到数据。
2)MylSAM是非聚集索引,数据文件是分离的,索引保存的是数据文件的指针。主键索引和辅助索引是独立的。
二.事务
1) 什么是事务?
事务是指在程序中一系列逻辑操作需要全部成功完成,否则在每个操作中的修改都会被撤销。
2) 事务的四个特性
(ACID)
- A 原子性,操作这些指令,要不全部执行成功,要不全部不执行。如果只要有一条指令执行失败,所有的指令都执行失败,数据需要回滚。
- C 一致性,整个数据的完整性保持稳定
- I 隔离性,多个用户并发访问数据库是,数据库为每一个用户开启的事务,不能被其他事务的操作干扰。
- D 持久性,当事务正确完成时,对数据的更改是永久的。
3) 并发事务导致的问题
- 撤销一个事务时,把其他事务已提交的更新数据覆盖。(银行存款100元,年费扣了5元,撤回存款100元,5元去哪了?)
- 脏读:一个事务处理过程中读取了另一个未提交的事务中的数据。
- 幻读:也叫虚读,一个事务执行两次查询,第二次结果包含第一次中没有或某些行已经被删除的数据,造成两次结果不一致,这是另一个事务在这两次查询中插入或者删除数据造成的。
- 不可重复读:一个事务两次读取同一行数据,结果得到不同状态的结果,中间正好另一个事务更新了该数据,两次结果不一致,不可被信任。(另一事务提交了数据)
4) 数据库事务的隔离级别
MVCC
读未提交 -> 导致脏读
读已提交 -> 解决脏读 -> 可能会产生不可重复读
可重复读 -> 解决脏读和不可重复读 -> 可能会产生幻读
序列化 串行化执行
参考文献:
[1] https://cloud.tencent.com/developer/article/1133074
这篇关于2021-09-24 数据库总结的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!