搜尋

首頁  >  問答  >  主體

mysql普通索引效率

select * from post where zhuanid = 0 and catid <> 10 and empty =0;
1、本SQL语句:唯一性太差的还要建索引吗 比如empty 就是0或者1 catid一共就8个数 但表数据量是上百万

2、还有2个及2个以上条件查询的 必须要将全部字段建一个复合索引吗

3、如果如上三个字段分别建了一个普通索引 这个and会使用索引吗

对多个查询条件的索引概念比较模糊 但我现在数据库的CPU非常高

巴扎黑巴扎黑2767 天前514

全部回覆(3)我來回復

  • 高洛峰

    高洛峰2017-04-17 16:40:20

    具體問題具體分析。唯一性太差的沒必要建立獨立索引。建議建立聯合索引,並調整查詢語句。 (zhanid,catid,empty)。語句改寫成 zhuanid = 0 and catid in(a,b,c,d,e) and empty =0

    回覆
    0
  • 迷茫

    迷茫2017-04-17 16:40:20

    <> 這個是不是乾掉索引了?

    負向查詢條件:NOT、!=、<>、!<、!>、NOT IN、NOT LIKE等,會導致全表掃描

    回覆
    0
  • 阿神

    阿神2017-04-17 16:40:20

    select 值得懷疑一下是否是必要的,分別索引的話,mysql優化器會有自己的判斷。你這個可以走覆蓋索引

    回覆
    0
  • 取消回覆