MySQL 索引的使用场景

应该创建索引的场景

  • 主键应该创建主键索引。
  • 频繁作为查询条件的字段应该创建索引。
  • 查询中需要与其他表进行关联的字段应该创建索引。
  • 需要排序的字段应该创建索引。
  • 需要统计或分组的字段应该创建索引。
  • 优先考虑创建复合索引。

不适合创建索引的场景

  • 频繁更新的字段不适合创建索引。
  • 查询条件中用不到的字段不适合创建索引。

不应创建索引的场景

  • 数据记录较少的表。
  • 经常需要增删改操作的字段。
  • 数据记录重复较多且分布平均的字段(如性别、状态等)。
索引的选择性是指索引列中不同值的数目与表中记录总数的比。
索引的选择性越接近于1,创建索引的价值就越高。反之就越低。

MySQL 常见的性能瓶颈

  • CPU:通常发生在数据载入内存或从磁盘上读取数据时。
  • IO:通常发生在载入数据远大于内存容量时。
  • 服务器硬件:通过top,free,iostat,vmstat等命令查看系统的性能状况。

你可能感兴趣的:(mysql)