mysql-数据库三大范式是什么、mysql有哪些索引类型,分别有什么作用 、 事务的特性和隔离级别

1. 数据库三大范式是什么?

python 复制代码
数据库三大范式是设计关系型数据库时的规范化原则,确保数据库结构的合理性和减少数据冗余。
这三大范式分别是:
- **第一范式(1NF):** 数据表中的所有列都是不可分割的原子数据项,即每一列都不可再分。
	这消除了重复的列。
- **第二范式(2NF):** 数据表中的非主键列完全依赖于主键。
	这意味着每一行数据都能通过唯一的主键来识别,并且非主键列不能部分依赖于主键。
- **第三范式(3NF):** 数据表中的非主键列之间不存在传递依赖关系。
	换句话说,非主键列不能依赖于其他非主键列。

2. MySQL有哪些索引类型,分别有什么作用?

python 复制代码
MySQL支持多种类型的索引,其中一些主要的索引类型包括:
	- **B-Tree 索引:** 这是最常见的索引类型,适用于等值查询、范围查询和排序操作。
	- **哈希索引:** 适用于等值查询,但不支持范围查询和排序操作。在内存表上效果更好。
	- **全文索引:** 用于全文搜索,适用于包含文本的列。支持全文搜索的操作。
	- **空间索引:** 用于空间数据类型,如地理坐标数据。
	- **前缀索引:** 只索引列值的一部分,可以用于减小索引大小。
	- **组合索引:** 将多个列组合成一个索引,用于满足多列的查询需求。

3. 事务的特性和隔离级别

python 复制代码
**事务的四个特性(ACID):**
	- **原子性(Atomicity):** 事务是一个不可分割的工作单位,要么全部执行,要么全部不执行。
	- **一致性(Consistency):** 事务执行后,数据库从一个一致的状态变到另一个一致的状态,
		保持数据库的完整性。
	- **隔离性(Isolation):** 多个事务并发执行时,每个事务都应该感觉不到其他事务的存在,
		它们之间是隔离的。
	- **持久性(Durability):** 事务一旦提交,对数据库的改变应该是永久性的。

**事务的隔离级别:**
	- **READ UNCOMMITTED(读取未提交):** 允许读取其他事务未提交的数据,
		可能导致脏读、不可重复读和幻读。
	- **READ COMMITTED(读取已提交):** 只能读取已经提交的数据,解决了脏读问题,
		但仍可能存在不可重复读和幻读。
	- **REPEATABLE READ(可重复读):** 保证了在同一事务中多次读取同一数据时,结果保持一致。
		解决了脏读和不可重复读问题,但仍可能存在幻读。
	- **SERIALIZABLE(可串行化):** 最高的隔离级别,通过强制事务串行执行来解决所有并发问题,
		包括脏读、不可重复读和幻读。

随着隔离级别的提高,事务的并发性能通常会降低,因为更高的隔离级别通常需要更多的锁和资源。选择隔离级别时需要权衡一致性和性能的需求。
相关推荐
正在走向自律6 分钟前
Oracle迁移实战:从兼容性挑战到平滑过渡金仓数据库的解决方案
数据库·oracle·国产数据库·金仓数据库·兼容性挑战·迁移成本
QAQalone14 分钟前
MySQL实际项目中常用的 DDL 模板
数据库·mysql
Evand J16 分钟前
【MATLAB例程】二维指纹对目标的一段轨迹定位,锚点数量可调。输出位置真值、估计值对比,附代码下载链接
开发语言·数据库·matlab
赵渝强老师22 分钟前
【赵渝强老师】国产金仓数据库的体系架构
数据库·oracle·架构
此生只爱蛋27 分钟前
【Redis】浅谈数据结构和内部编码和单线程架构
数据结构·数据库·redis
工藤学编程28 分钟前
零基础学AI大模型之新版LangChain向量数据库VectorStore设计全解析
数据库·人工智能·langchain
+VX:Fegn089535 分钟前
计算机毕业设计|基于springboot + vue服装商城系统(源码+数据库+文档)
数据库·vue.js·spring boot
SoleMotive.36 分钟前
Mysql底层的数据结构,为什么用B+树,如果在内存中,B树和B+树查询效率怎么样
数据结构·b树·mysql
JIngJaneIL37 分钟前
基于Java在线考试管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
计算机毕设指导640 分钟前
基于微信小程序的篮球场馆预订系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven