Rumah > Artikel > pangkalan data > Situasi pertanyaan manakah dalam mysql yang tidak menggunakan indeks?
1 Lajur indeks mengambil bahagian dalam pengiraan dan tidak menggunakan indeks
SELECT `username` FROM `t_user` WHERE age=20;-- 会使用索引 SELECT `username` FROM `t_user` WHERE age+10=30;-- 不会使用索引!!因为所有索引列参与了计算 SELECT `username` FROM `t_user` WHERE age=30-10;-- 会使用索引
2 tidak menggunakan indeks
-- 不会使用索引,因为使用了函数运算,原理与上面相同 SELECT username FROM t_user WHERE concat(username,'1') = 'admin1'; -- 会使用索引 SELECT username FROM t_user WHERE username = concat('admin','1');
3 Gunakan pernyataan serupa untuk lajur indeks, dan mungkin tidak menggunakan indeks
SELECT * FROM USER WHERE username LIKE 'mysql测试%' --走索引 SELECT * FROM USER WHERE username LIKE '%mysql测试' --不走索引 SELECT * FROM USER WHERE username LIKE '%mysql测试%' --不走索引
4. Penukaran tersirat jenis data, perbandingan langsung antara lajur rentetan dan nombor, tanpa menggunakan indeks
-- stock_code字符串类型带索引 SELECT * FROM `stock_data` WHERE stock_code = '600538' --走索引 SELECT * FROM `stock_data` WHERE stock_code = 600538 --不走索引
5. Cuba elakkan operasi ATAU, selagi satu medan tidak mempunyai indeks, indeks tidak akan digunakan semasa menukar pernyataan, dan indeks tidak akan digunakan!
-- stock_code带索引,open不带索引 SELECT * FROM `stock_data` WHERE `stock_code` = '600538' OR `open` = 6.62 -- 不走索引 -- stock_code带索引,up_down_pre带索引 SELECT * FROM `stock_data` WHERE `stock_code` = '600538' OR `up_down_pre` = 5.1 -- 走索引
6 di mana id !=2 atau di mana id a8093152e673feb7aba1828c43532094
SELECT * FROM t_user WHERE username <> 'mysql测试'
7. Jika ia adalah batal atau tidak, anda tidak boleh menggunakan indeks.
SELECT * FROM t_user WHERE username IS NULL -- 不走索引 SELECT * FROM t_user WHERE username IS NOT NULL -- 不走索引
8. Lajur indeks menggunakan pernyataan dalam, dan indeks mungkin tidak digunakan
-- stock_code数据类型为varchar SELECT * FROM `stock_data` WHERE `stock_code` IN ('600538') -- 走索引 SELECT * FROM `stock_data` WHERE `stock_code` IN ('600538','688663','688280') -- 走索引 SELECT * FROM `stock_data` WHERE `stock_code` IN (大量数据) -- 不走索引 SELECT * FROM `stock_data` WHERE `stock_code` IN (600538) -- 不走索引
1. Tiada syarat pertanyaan atau syarat pertanyaan Tiada indeks dalam pangkalan data perniagaan, terutamanya jadual dengan jumlah data yang besar.
Cadangan:
1 Tukar kepada lajur diindeks sebagai syarat pertanyaan
2 Atau indeks lajur yang kerap ditanya
2 set hasil adalah kebanyakan data dalam jadual asal, yang sepatutnya lebih daripada 25%
Jika set hasil pertanyaan melebihi 25% daripada jumlah baris, pengoptimum merasakan bahawa tiada perlu mengindeks .
Cadangan:
1 Jika perniagaan membenarkan, anda boleh menggunakan kawalan had.
2 Berdasarkan pertimbangan perniagaan, adakah cara yang lebih baik? Jika tiada penyelesaian penulisan semula yang lebih baik
3 cuba jangan simpan data ini dalam mysql. Letakkan dalam redis.
3. Indeks itu sendiri tidak sah dan statistiknya tidak benar
Indeks mempunyai keupayaan untuk mengekalkan diri Apabila kandungan jadual kerap berubah, indeks mungkin kelihatan Tidak sah.
Tukar pelan:
Sandarkan data jadual, padam dan bina semula jadual yang berkaitan.
4. Syarat pertanyaan menggunakan fungsi pada lajur indeks atau melaksanakan operasi pada lajur indeks termasuk (+, -, *, /,!, dsb.)
Tukar kaedah: Kurangkan penggunaan operasi pengiraan seperti tambah, tolak, darab dan bahagi dalam mysql.5. Penukaran tersirat menyebabkan kegagalan indeks Ini juga merupakan kesilapan biasa dalam pembangunan. ) ;select * from stu where name = ‘111';走索引
select * from stu where name = 111;不走索引
Tukar kaedah:
Berunding dengan R&D, dan pertanyaan pernyataan mematuhi spesifikasi.
6.a8093152e673feb7aba1828c43532094, tidak masuk tanpa pengindeksan (indeks tambahan)Tukar kaedah: Cuba jangan gunakan kaedah di atas untuk pertanyaan , atau pilih lajur indeks sebagai syarat penapis.
Individu>,<,dalam mungkin atau mungkin tidak pergi.Cuba tambah had
atau atau mengikut perniagaan kesatuan
7.seperti “%” tanpa tanda peratus di hadapanEXPLAIN SELECT * FROM teltab WHERE telnum LIKE ‘31%' 走索引 EXPLAIN SELECT * FROM teltab WHERE telnum LIKE ‘%110' 不走索引
Kaedah tukar: Untuk keperluan carian kelas %linux% , anda boleh menggunakan elasticsearch +mongodb ialah produk pangkalan data yang mengkhusus dalam perkhidmatan carian
Atas ialah kandungan terperinci Situasi pertanyaan manakah dalam mysql yang tidak menggunakan indeks?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!