mysql千萬數(shù)據(jù)加索引卡死關鍵字?
寶雞ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18982081108(備注:SSL證書合作)期待與您的合作!
想到了從以下方法進行解決:
1)重寫Sql,讓查詢命中索引
2)增加索引
3)1)或者2)方法之后,再加上一個緩存功能
最快捷的方式肯定是2了,但是本表由于邏輯復雜,時不時又批量錄入一些數(shù)據(jù),已經(jīng)有了5個索引了,再加索引,恐怕會導致寫入慢的問題,而且加索引可能會引起鎖表問題。
于是,我先想用方法1解決,可是由于邏輯有點復雜,查詢語句比較復雜,改了很多寫法都不理想,最后還是選擇了方法2,直接表加索引。
由于對于加索引的一些擔憂,于是我在本地先嘗試了一下(本地數(shù)據(jù)和線上數(shù)據(jù)量基本一致,相差不大),結果沒想到還挺快的,對于寫入的性能也沒多大的影響。加入索引后頁面秒開,效果很好。
我們簡單建了一張表,如下:
我們建立了兩個索引,分別為主鍵索引id和普通索引product_id
如果我們的where條件中存在or,及時其中帶索引,也不會命中索引。這也是為什么盡量使用or的原因
我們通過主鍵索引查詢,可以看見命中了索引:
而我們在where 條件后面加上or之后,就不會命中索引了:
可以看到如果用like查詢的話,%在右邊會命中索引的,而%在左邊則不會。當然這也不是絕對的,當我們使用索引列進行查詢的時候,就都會命中索引了:
NOT IN,NOT LIKE,NOT EXTSTS都不會命中索引
1.添加PRIMARY KEY(主鍵索引):
2.添加UNIQUE(唯一索引) :
3.添加INDEX(普通索引) :
4.添加FULLTEXT(全文索引) :
5.添加多列索引:
兄弟,primary key是主鍵,每個表只能有一個主鍵,而且數(shù)據(jù)是唯一的。\x0d\x0a可以這樣寫:\x0d\x0aCREATE TABLE IF NOT EXISTS `".$ctb_name."` (\x0d\x0a `id` INT(9) NOT NULL AUTO_INCREMENT PRIMARY KEY,\x0d\x0a `keyid` VARCHAR(20) NOT NULL,\x0d\x0a `key` VARCHAR(20) NOT NULL,\x0d\x0a `stauts` BOOL NOT NULL DEFAULT'0',\x0d\x0aindex `idx_status`(`status`)\x0d\x0a )ENGINE = MYISAM DEFAULT CHARSET=utf8;\x0d\x0a不過,status是bool類型的字段,只有true和false,區(qū)分度太低,沒有必要加索引。\x0d\x0a\x0d\x0a索引目的是為了使查詢更快,區(qū)分度小的時候不如全表掃描。