Logik Bersyarat dalam SQL WHERE Klausa: Panduan Praktikal
KlausaSQL WHERE
biasanya menggunakan ungkapan Boolean untuk penapisan. Walau bagaimanapun, menggabungkan logik bersyarat yang lebih kompleks memerlukan pendekatan alternatif. Walaupun kenyataan IF
langsung tidak disokong dalam klausa WHERE
dalam banyak dialek SQL (termasuk Microsoft SQL Server), kami boleh mencapai hasil yang sama menggunakan kaedah lain.
Kenyataan KES: Penyelesaian Teguh
Pernyataan CASE
menyediakan cara yang berkuasa untuk mengendalikan logik bersyarat dalam klausa WHERE
. Ia menilai berbilang keadaan dan mengembalikan nilai berdasarkan hasil.
Mari kita ilustrasikan dengan contoh. Katakan kita ingin mencari OrderNumber
berdasarkan sama ada ia adalah angka:
<code class="language-sql">WHERE OrderNumber LIKE CASE WHEN IsNumeric(@OrderNumber) = 1 THEN @OrderNumber ELSE '%' + @OrderNumber + '%' END</code>
Pernyataan CASE
ini menyemak sama ada @OrderNumber
adalah angka menggunakan IsNumeric()
. Jika ia (kembali 1), ia melakukan padanan yang tepat. Jika tidak, ia menggunakan kad bebas (%
) untuk mencari padanan separa, mengendalikan input bukan angka dengan berkesan.
Pendekatan Alternatif: Menggunakan IF (dengan Berhati-hati)
Sesetengah dialek SQL mungkin membenarkan pernyataan IF
dalam klausa WHERE
, tetapi ini selalunya bergantung pada sistem pangkalan data tertentu dan boleh membawa kepada pertanyaan yang kurang boleh dibaca dan berpotensi kurang cekap. Contohnya (sintaks mungkin berbeza-beza bergantung pada pangkalan data anda):
<code class="language-sql">WHERE (CASE WHEN IsNumeric(@OrderNumber) = 1 THEN OrderNumber = @OrderNumber ELSE OrderNumber LIKE '%' + @OrderNumber + '%' END)</code>
Ini mencapai kefungsian yang sama seperti contoh pernyataan CASE
di atas tetapi mungkin tidak semudah mudah alih atau semudah difahami.
Pertimbangan Penting:
Logik bersyarat yang terlalu kompleks dalam fasal WHERE
boleh memberi kesan negatif terhadap prestasi pertanyaan dan kebolehbacaan. Untuk kecekapan dan kebolehselenggaraan yang optimum, utamakan pernyataan CASE
yang jelas dan ringkas apabila melaksanakan logik bersyarat dalam pertanyaan SQL anda. Sentiasa menguji dan mengoptimumkan pertanyaan anda untuk sistem pangkalan data khusus anda.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Logik Bersyarat dalam Klausa SQL WHERE?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!