mysql基础面试题

最近对mysql的基础知识很感兴趣,所以希望通过查询网络上的面试题来巩固下基础,所以如下

1 普通索引跟唯一索引应该如何选择

在 MySQL(InnoDB)里,"普通二级索引(KEY)"和"唯一索引(UNIQUE KEY)"在存储结构、查询性能上几乎一模一样,真正的差异只有三点:

  1. 唯一索引多一道"唯一性约束"检查
  2. 唯一索引对优化器的基数估计更准,某些场景能拿到更优的执行计划
  3. 唯一索引不能存重复值,因此插入/更新时可能多一次"冲突检测"往返
  • 查询

    • 当普通索引为条件时查询到数据会一直扫描,直到扫完整张表
    • 当唯一索引为查询条件时,查到该数据会直接返回,不会继续扫表
  • 更新

    • 普通索引会直接将操作更新到 change buffer 中,然后结束
    • 唯一索引需要判断数据是否冲突

所以**「唯一索引更加适合查询的场景,普通索引更适合插入的场景」**

2 一条sql命令一直查询慢的原因是什么

「1.没有用到索引」

  • 比如函数导致的索引失效,或者本身就没有加索引

「2.表数据量太大」

  • 考虑分库分表吧

「3.优化器选错了索引」

  • 「考虑使用」 force index 强制走索引
相关推荐
霖霖总总29 分钟前
[小技巧37]解构 my.cnf:[client] 与 [mysql] 背后的加载逻辑与优先级
运维·mysql
liux352830 分钟前
MySQL日志系统全面解析:从基础到高级管理(六)
数据库·mysql·oracle
Maggie_ssss_supp1 小时前
Linux-MySQL日志管理
数据库·mysql
熬夜敲代码的小N1 小时前
MySQL数据可视化实战:从SQL雕琢到图表绽放
sql·mysql·信息可视化
独自归家的兔2 小时前
深度对比:PostgreSQL与MySQL的核心差异及选型指南
数据库·mysql·postgresql
霖霖总总2 小时前
[小技巧36]MySQL 配置参数全解:参数含义、作用域与运维建议
运维·数据库·mysql
凌冰_2 小时前
Thymeleaf Maven+Servlet+Mysql图书框架—2(八)
java·mysql·maven
凌冰_2 小时前
Thymeleaf Maven+Servlet+Mysql图书框架—3(九)
mysql·servlet·maven
狂龙骄子3 小时前
MySQL表字段批量修改SQL实战技巧
数据库·sql·mysql·alter table·批量修改·sql实战技巧
独隅3 小时前
Linux 正则表达式 的简介
linux·mysql·正则表达式