排序
面试题:为什么 Redis 设计为单线程?6.0 版本为何引入多线程?
Redis 的设计和演进是一个典型的“性能与复杂性的权衡”案例。以下是详细解答: 一、为什么 Redis 设计为单线程? Redis 早期采用单线程模型,主要基于以下核心原因: 1. 性能瓶颈不在 CPU,而...
面试题:Redis 中有哪些内存淘汰策略?
Redis 提供了 8 种内存淘汰策略,用于在内存不足时自动删除数据,以腾出空间容纳新数据。这些策略分为 4 类:LRU(最近最少使用)、LFU(最不经常使用)、Random(随机) 和&nbs...
面试题:什么是数据库的视图?
数据库视图是什么? 数据库视图(View) 是一种虚拟表,它并不实际存储数据,而是通过SQL查询动态生成的结果集。视图的定义保存在数据库中,但其数据始终来源于底层的基表(或其它视图),...
面试题:Redis 和 Memcached 有哪些区别?
Redis 和 Memcached 都是高性能的内存键值存储系统,但它们在功能、性能和使用场景上存在一些关键差异。以下是它们的主要区别: 一、数据类型支持 Redis:支持多种数据结构,包括字符串(String...
面试题:MySQL 索引的最左前缀匹配原则是什么?
MySQL 索引的最左前缀匹配原则(Leftmost Prefix Principle) 核心概念 最左前缀匹配原则 是 MySQL 使用联合索引(复合索引)时的一个重要规则。它要求查询条件必须从联合索引的最左侧列开...
场景题:如果组长要求你主导项目中的分库分表,大致的实施流程是?
主导分库分表的实施流程 1. 需求分析与方案设计 明确目标 解决单库单表性能瓶颈(如查询延迟、写入吞吐不足)。 支持未来3-5年的业务增长(预估数据量、并发量)。 是否需要支持高可用、弹性扩...
面试题:MySQL 中如果发生死锁应该如何解决?
在 MySQL 中,死锁是指两个或多个事务在等待对方释放资源,从而导致这些事务永远处于等待状态的情况。MySQL 的 InnoDB 存储引擎能够自动检测到死锁,并回滚其中一个事务来解决这个问题。 然而,...
面试题:相比于 Oracle,MySQL 的优势有哪些?
在数据库领域,MySQL 与 Oracle 各有优劣,但 MySQL 在 成本、易用性、灵活性和轻量级场景 中具有显著优势。以下是 MySQL 相比 Oracle 的核心优势总结: 1. 成本效益:开源免费,降低企业成本 ...
面试题:为什么不推荐在 MySQL 中直接存储图片、音频、视频等大容量内容?
在MySQL中直接存储图片、音频、视频等大容量内容(通常称为BLOB/BIG BLOB数据)通常不被推荐,主要原因包括以下几点: 1. 性能问题 存储效率:存储大容量文件(如图片、音频、视频)会大幅增加...
面试题:如何在 MySQL 中实现读写分离?
在 MySQL 中实现读写分离主要是为了提高数据库的并发性能和资源利用率,特别是在高负载的应用环境中。 通过将读操作分配给从库(Slave),而写操作则发送到主库(Master),可以有效减轻单一数...
