排序
面试题:MySQL 默认的事务隔离级别是什么?为什么选择这个级别?
MySQL 默认的事务隔离级别是 可重复读(Repeatable Read),这是由 InnoDB 存储引擎提供的默认设置。选择这个级别的原因主要有以下几点: 为什么选择可重复读(Repeatable Read) 防止脏读:在...
面试题:为什么 Redis Zset 用跳表实现而不是红黑树?B+树?
Redis 的 有序集合(ZSet) 选择使用 跳表(Skip List) 而不是 红黑树(Red-Black Tree) 或 B+树,主要是基于以下多维度的权衡和优化需求。以下是详细分...
面试题:在 MySQL 中存储金额数据,应该使用什么数据类型?
在 MySQL 中存储金额数据时,推荐使用 DECIMAL 数据类型。这是金融领域和精确数值计算的行业标准选择,原因如下: 1. 为什么选择 DECIMAL? 精确性保障DECIMAL 是定点数类型,能够避免浮点型(F...
面试题:Redis Zset 的实现原理是什么?
Redis 的 ZSet(有序集合) 是 Redis 提供的一种高性能数据结构,既能保证元素的 唯一性,又能通过 分数(Score)进行排序。其底层实现结合了 跳表(Skip List) ...
面试题:Redis 的 hash 是什么?
在 Redis 中,Hash(哈希) 是一种数据结构,它可以存储一个字符串字段和值之间的映射关系。Redis 的 Hash 类似于编程语言中的字典或对象的概念,非常适合用来表示对象。每个 Hash 可以存储多达...
面试题:什么是 Write-Ahead Logging (WAL) 技术?它的优点是什么?MySQL 中是否用到了 WAL?
Write-Ahead Logging (WAL) 是一种用于确保数据完整性和加速数据库恢复过程的技术。 其基本思想是在对数据进行修改之前,先将这些修改操作的日志记录写入持久存储(通常是磁盘)。 只有当日志成...
面试题:MySQL 中 EXISTS 和 IN 的区别是什么?
在 MySQL 中,EXISTS 和 IN 都是用于子查询的关键字,但它们的工作机制和使用场景有所不同。 EXISTS 功能:EXISTS 用于检测子查询是否返回行。如果子查询返回一行或多行,则 EXISTS 的结果为 TR...
面试题:数据库的三大范式是什么?
数据库的三大范式是数据库设计中用于减少数据冗余、提高数据一致性和完整性的规范规则。以下是它们的详细说明: 1. 第一范式(1NF) 定义:表中的每一列都是不可分割的原子值(最小单元),即字...
面试题:MySQL 的存储引擎有哪些?它们之间有什么区别?
MySQL 的存储引擎是其核心功能之一,不同的存储引擎支持不同的特性、性能优化和适用场景。以下是常见的 MySQL 存储引擎及其区别: 一、常见存储引擎 InnoDB(默认引擎) 特点: 事务支持:支持 ...
面试题:相比于 Oracle,MySQL 的优势有哪些?
在数据库领域,MySQL 与 Oracle 各有优劣,但 MySQL 在 成本、易用性、灵活性和轻量级场景 中具有显著优势。以下是 MySQL 相比 Oracle 的核心优势总结: 1. 成本效益:开源免费,降低企业成本 ...
