数据库共127篇

面试题:在什么情况下,不推荐为数据库建立索引?

虽然索引在数据库中对于提高查询效率非常有用,但在某些特定情况下,建立索引可能并不是最佳选择。以下是一些不推荐为数据库建立索引的情况: 频繁更新的表:如果一个表中的数据频繁地被插入、...
程序百科的头像-程序百科程序百科1个月前
366

面试题:MySQL 中 EXISTS 和 IN 的区别是什么?

在 MySQL 中,EXISTS 和 IN 都是用于子查询的关键字,但它们的工作机制和使用场景有所不同。 EXISTS 功能:EXISTS 用于检测子查询是否返回行。如果子查询返回一行或多行,则 EXISTS 的结果为 TR...
程序百科的头像-程序百科程序百科1个月前
2314

面试题:什么是 Write-Ahead Logging (WAL) 技术?它的优点是什么?MySQL 中是否用到了 WAL?

Write-Ahead Logging (WAL) 是一种用于确保数据完整性和加速数据库恢复过程的技术。 其基本思想是在对数据进行修改之前,先将这些修改操作的日志记录写入持久存储(通常是磁盘)。 只有当日志成...
程序百科的头像-程序百科程序百科1个月前
2614

面试题:你们生产环境的 MySQL 中使用了什么事务隔离级别?为什么?

在生产环境中选择MySQL的事务隔离级别主要取决于应用的具体需求,包括数据一致性、并发性能以及可能出现的并发问题(如脏读、不可重复读和幻读)。 MySQL支持四种标准的事务隔离级别:READ UNCO...
程序百科的头像-程序百科程序百科1个月前
3211

面试题:为什么阿里巴巴的 Java 手册不推荐使用存储过程?

阿里巴巴的《Java开发手册》中不推荐使用存储过程,主要是基于以下几个方面的考量: 可移植性差:存储过程依赖于特定的数据库管理系统(DBMS),这意味着如果你的应用程序需要更换数据库系统,...
程序百科的头像-程序百科程序百科1个月前
296

场景题:如何实现数据库的不停服迁移?

实现数据库的不停服迁移是许多企业系统升级或架构调整时的核心需求,以下是几种成熟的解决方案: 一、主流迁移方案对比 方案适用场景停机时间复杂度数据一致性保证主从复制版本升级、机房迁移秒...
程序百科的头像-程序百科程序百科1个月前
519

面试题:MySQL 数据库的性能优化方法有哪些?

MySQL 性能优化是一个系统工程,需要从多个层面进行分析和调优。以下是分层次的优化方法: 一、SQL 语句优化(最直接有效) 1. 查询优化 **避免 SELECT ***:只查询需要的列 合理使用索引: -- ...
程序百科的头像-程序百科程序百科1个月前
2413

面试题:MySQL 中 InnoDB 存储引擎与 MyISAM 存储引擎的区别是什么?

MySQL中的InnoDB和MyISAM是两种常用的存储引擎,它们各自具有不同的特点和适用场景。以下是这两种存储引擎的主要区别: 事务支持 InnoDB:支持事务处理(ACID兼容),提供提交、回滚和崩溃恢复...
程序百科的头像-程序百科程序百科1个月前
339

面试题:MySQL 的查询优化器如何选择执行计划?

MySQL的查询优化器在决定执行计划时会考虑多种因素,以确保查询尽可能高效地运行。以下是优化器选择执行计划时的一些关键步骤和考虑因素: 统计信息:MySQL使用表和索引的统计信息来评估不同执...
程序百科的头像-程序百科程序百科1个月前
247

面试题:什么是数据库的逻辑删除?数据库的物理删除和逻辑删除有什么区别?

逻辑删除与物理删除的概念 逻辑删除:指的是在数据库中不实际移除数据记录,而是通过标记的方式(如增加一个is_deleted字段,并将其值设为true或1)来表示该记录已被“删除”。这样做的好处是可...
程序百科的头像-程序百科程序百科1个月前
238