Situasi pertanyaan manakah dalam mysql yang tidak menggunakan indeks?

WBOY
Lepaskan: 2023-05-29 21:19:04
ke hadapan
2940 orang telah melayarinya

Pertanyaan 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;-- 会使用索引
Salin selepas log masuk

2 tidak menggunakan indeks

-- 不会使用索引,因为使用了函数运算,原理与上面相同
SELECT username FROM t_user WHERE concat(username,'1') = 'admin1'; 
-- 会使用索引
SELECT username FROM t_user WHERE username = concat('admin','1');
Salin selepas log masuk

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测试%'  --不走索引
Salin selepas log masuk

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  --不走索引
Salin selepas log masuk

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  -- 走索引
Salin selepas log masuk

6 di mana id !=2 atau di mana id <>

SELECT * FROM t_user WHERE username <> &#39;mysql测试&#39;
Salin selepas log masuk

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 -- 不走索引
Salin selepas log masuk

8. Lajur indeks menggunakan pernyataan dalam, dan indeks mungkin tidak digunakan

-- stock_code数据类型为varchar
SELECT * FROM `stock_data` WHERE `stock_code` IN (&#39;600538&#39;)  -- 走索引
SELECT * FROM `stock_data` WHERE `stock_code` IN (&#39;600538&#39;,&#39;688663&#39;,&#39;688280&#39;)  -- 走索引
SELECT * FROM `stock_data` WHERE `stock_code` IN (大量数据)  -- 不走索引
SELECT * FROM `stock_data` WHERE `stock_code` IN (600538)  -- 不走索引
Salin selepas log masuk

Situasi tidak menggunakan indeks:

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&#39;;走索引
select * from stu where name = 111;不走索引
Salin selepas log masuk
Tukar kaedah:

Berunding dengan R&D, dan pertanyaan pernyataan mematuhi spesifikasi.

6.<>, 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 hadapan

EXPLAIN SELECT * FROM teltab WHERE telnum LIKE ‘31%&#39; 走索引
EXPLAIN SELECT * FROM teltab WHERE telnum LIKE ‘%110&#39; 不走索引
Salin selepas log masuk

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!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!