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(可串行化):** 最高的隔离级别,通过强制事务串行执行来解决所有并发问题,
		包括脏读、不可重复读和幻读。

随着隔离级别的提高,事务的并发性能通常会降低,因为更高的隔离级别通常需要更多的锁和资源。选择隔离级别时需要权衡一致性和性能的需求。
相关推荐
m0_5145205711 分钟前
MySQL索引优化后性能没提升_通过EXPLAIN查看索引命中率
jvm·数据库·python
NaMM CHIN19 分钟前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
不瘦80斤不改名33 分钟前
深入浅出 MySQL(一):一文理清 SQL 核心规范与五大分类
数据库·sql·mysql
woniu_buhui_fei40 分钟前
MySQL知识整理二
数据库·mysql
Polar__Star2 小时前
如何在 AWS Lambda 中正确使用临时凭证生成 S3 预签名 URL
jvm·数据库·python
Lucifer三思而后行2 小时前
zCloud 中 Oracle 实例状态未知问题记录
数据库·oracle
island13142 小时前
最详细VMware Workstation 17 上安装 Ubuntu 系统
linux·数据库·ubuntu
卢傢蕊2 小时前
MongoDB
数据库·mongodb
m0_743623922 小时前
React 自定义 Hook 的命名规范与调用规则详解
jvm·数据库·python
古城小栈2 小时前
GORM 操作 PostgreSQL 高级类型
数据库·postgresql