Rumah > pangkalan data > tutorial mysql > Mengapakah Keadaan `IN` SQL Kadangkala Lebih Lambat Daripada Operator `=`?

Mengapakah Keadaan `IN` SQL Kadangkala Lebih Lambat Daripada Operator `=`?

Mary-Kate Olsen
Lepaskan: 2025-01-16 17:13:08
asal
154 orang telah melayarinya

Why is SQL's `IN` Condition Sometimes Slower Than the `=` Operator?

Keadaan IN SQL: Isu Prestasi Berbanding =

Dalam situasi tertentu, keadaan IN SQL boleh berprestasi rendah dengan ketara berbanding pengendali =. Ini adalah isu yang ketara dalam versi MySQL yang lebih lama, walaupun versi kemudian (MySQL 5.6 dan seterusnya) telah menangani perkara ini.

Perbezaan prestasi berpunca daripada cabaran pengoptimuman. Subkueri dalam klausa IN mungkin salah dikenal pasti sebagai bergantung, bukannya bebas. Ini membawa kepada pelaksanaan berulang subkueri untuk setiap baris dalam pertanyaan utama, memberi kesan secara dramatik pada prestasi.

Mari kita lihat contoh:

<code class="language-sql">SELECT * FROM question_law_version
WHERE question_law_id IN (
    SELECT MAX(foo_id)
    FROM bar
);</code>
Salin selepas log masuk

Pelan EXPLAIN untuk pertanyaan ini mungkin mendedahkan:

<code>1  'PRIMARY'             'question_law_version'  'ALL'  ''  ''  ''  ''  10148  'Using where'
2  'DEPENDENT SUBQUERY'  'question_law_version'  'ALL'  ''  ''  ''  ''  10148  'Using where'
3  'DEPENDENT SUBQUERY'  'question_law'          'ALL'  ''  ''  ''  ''  10040  'Using where'</code>
Salin selepas log masuk

Perhatikan sebutan "SUBQUERY BERGANTUNG". Pertanyaan dalaman berulang kali dilaksanakan. Walau bagaimanapun, menulis semula pertanyaan menggunakan = (dengan mengandaikan subkueri mengembalikan nilai tunggal):

<code class="language-sql">SELECT * FROM question_law_version
WHERE question_law_id = (
    SELECT MAX(foo_id)
    FROM bar
);</code>
Salin selepas log masuk

...selalunya menghasilkan rancangan yang lebih cekap:

<code>1  'PRIMARY'   'question_law_version'  'ALL'  ''  ''  ''  ''  10148  'Using where'
2  'SUBQUERY'  'question_law_version'  'ALL'  ''  ''  ''  ''  10148  'Using where'
3  'SUBQUERY'  'question_law'          'ALL'  ''  ''  ''  ''  10040  'Using where'</code>
Salin selepas log masuk

Perbezaan utama ialah klasifikasi "SUBQUERY", yang menunjukkan satu pelaksanaan. Percanggahan prestasi ini timbul daripada salah tafsiran MySQL (dalam versi lama) terhadap pergantungan subkueri klausa IN. Pengendalian pangkalan data yang tidak cekap ini membawa kepada kelembapan prestasi.

Atas ialah kandungan terperinci Mengapakah Keadaan `IN` SQL Kadangkala Lebih Lambat Daripada Operator `=`?. 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