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

随着隔离级别的提高,事务的并发性能通常会降低,因为更高的隔离级别通常需要更多的锁和资源。选择隔离级别时需要权衡一致性和性能的需求。
相关推荐
星辰离彬30 分钟前
Java 与 MySQL 性能优化:MySQL连接池参数优化与性能提升
java·服务器·数据库·后端·mysql·性能优化
小苹果13572 小时前
阿里云mysql数据丢失,如何通过服务器备份在其他服务器上恢复数据,并获取mysql丢失数据,完成mysql数据恢复
服务器·mysql·阿里云
张璐月3 小时前
mysql join语句、全表扫描 执行优化与访问冷数据对内存命中率的影响
数据库·mysql
ruan1145143 小时前
MySQL4种隔离级别
java·开发语言·mysql
全干engineer5 小时前
ClickHouse 入门详解:它到底是什么、优缺点、和主流数据库对比、适合哪些场景?
数据库·clickhouse
Hellyc7 小时前
基于模板设计模式开发优惠券推送功能以及对过期优惠卷进行定时清理
java·数据库·设计模式·rocketmq
lifallen7 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
慕木兮人可10 小时前
Docker部署MySQL镜像
spring boot·后端·mysql·docker·ecs服务器
{⌐■_■}11 小时前
【Kafka】登录日志处理的三次阶梯式优化实践:从同步写入到Kafka多分区批处理
数据库·分布式·mysql·kafka·go