什么是最左前缀原则?

发布于 2019-12-18 10:24:31
关注者
0
被浏览
4470
1 个回答
  • 面试哥
    面试哥 2019-12-18
    为面试而生,有面试问题,就找面试哥。

    MySQL中的索引可以以一定顺序引用多列,这种索引叫作联合索引。如User表的name和city加联合索引就是(name,city),而最左前缀原则指的是,如果查询的时候查询条件精确匹配索引的左边连续一列或几列,则此列就可以被用到。如下:

    select * from user where name=xx and city=xx ; //可以命中索引

    select * from user where name=xx ; // 可以命中索引

    select * from user where city=xx ; // 无法命中索引

    这里需要注意的是,查询的时候如果两个条件都用上了,但是顺序不同,如 city= xx and name =xx,那么现在的查询引擎会自动优化为匹配联合索引的顺序,这样是能够命中索引的。

    由于最左前缀原则,在创建联合索引时,索引字段的顺序需要考虑字段值去重之后的个数,较多的放前面。ORDER BY子句也遵循此规则。

面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看