✅一个表有用户和时间两个列,现有3个需求:根据用户查;根据日期查;根据日期和用户查;问怎么建立索引?

典型回答

这是一个比较简单的索引创建的问题,其实考察的点无非就是一个联合索引和最左前缀匹配,这里不涉及到区分度的问题、也不涉及到索引失效的问题。所以还是比较简单的。

需求要求支持三种查询,其中两个是单列查询,一个是多列查询。那么只需要建立2个索引就够了。

1、建立用户id、日期的联合索引。来满足按照用户查询、和按照用户+日期查询,这样都可以走到这个索引上。

  • CREATE INDEX idx_user_date ON table_name (user, date);

2、建立时间索引。来满足按照时间查询。

  • CREATE INDEX idx_date ON table_name (date);

idxuserdate 联合索引中把用户放在最左边,就可以实现按照用户查询也能走到这个索引,同时按照用户+时间的查询也能走到这个索引。这样就可以减少重复的索引创建,用一个索引就能满足两个查询了。

另外,如果这张表中,用户的区分度不高,比如一共就没有多少用户,但是每个用户的单量很大,比如B类业务,那么可以考虑改一下索引:

1、建立日期、用户id的联合索引。来满足按照时间查询、和按照用户+日期查询,这样都可以走到这个索引上。

  • CREATE INDEX idx_date_user ON table_name (date,user);

2、建立用户索引。来满足按照用户查询。

  • CREATE INDEX idx_user ON table_name (user);

原文: https://www.yuque.com/hollis666/xkm7k3/xphxkbfeoxpnfgch