Rumah > pangkalan data > tutorial mysql > Padanan Rentetan MySQL: INSTR lwn. SEPERTI: Mana Yang Lebih Cekap?

Padanan Rentetan MySQL: INSTR lwn. SEPERTI: Mana Yang Lebih Cekap?

Susan Sarandon
Lepaskan: 2024-12-04 20:17:15
asal
890 orang telah melayarinya

MySQL String Matching: INSTR vs. LIKE: Which is More Efficient?

Padanan Rentetan Lajur MySQL: INSTR lwn. LIKE

Apabila mencari subrentetan dalam lajur MySQL jenis 'varchar', 'teks ', atau 'blob', dua kaedah carian biasa timbul: INSTR dan LIKE. Walau bagaimanapun, pendekatan manakah yang lebih cekap?

Soalan tertumpu pada sama ada INSTR, yang menggunakan fungsi INSTR untuk mencari kedudukan rentetan tertentu, atau SUKA, yang menggunakan pemadanan corak dengan kad bebas, adalah lebih optimum pilihan.

Perbandingan Prestasi

Tanda aras mendedahkannya untuk jadual penuh imbasan, INSTR dan LIKE mempamerkan prestasi yang serupa:

INSTR( columnname, 'mystring' ) > 0: 5.54 sec
columnname LIKE '%mystring%': 5.54 sec
Salin selepas log masuk

Walau bagaimanapun, perbezaan utama muncul apabila melakukan carian awalan pada lajur diindeks:

Name LIKE 'search%': 3.88 sec
Salin selepas log masuk

Dalam senario ini, LIKE dengan hanya kad bebas akhiran dengan ketara mengatasi prestasi INSTR.

Alternatif: Carian FULLTEXT

Walaupun kedua-dua INSTR dan LIKE terbukti berguna untuk pemadanan rentetan, adalah penting untuk ambil perhatian bahawa carian FULLTEXT cemerlang dalam kecekapan untuk carian subrentetan. Mereka memanfaatkan senarai perkataan yang diindeks, membolehkan prestasi sepantas kilat, terutamanya apabila mencari lajur besar. Pertimbangkan untuk menggunakan FULLTEXT apabila kelajuan diutamakan.

Atas ialah kandungan terperinci Padanan Rentetan MySQL: INSTR lwn. SEPERTI: Mana Yang Lebih Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan