Kembalikan Nilai Lalai Apabila Pertanyaan Tidak Mengembalikan Baris
Apabila menggunakan pertanyaan SQL untuk mendapatkan data dan tiada baris yang sepadan ditemui, ia boleh berguna untuk mengembalikan nilai lalai dan bukannya hasil kosong. Ini amat berguna apabila anda ingin memastikan sesuatu sentiasa dipaparkan, walaupun tiada data untuk ditunjukkan.
Pertimbangkan pernyataan SQL berikut:
<code class="sql">SELECT `file` FROM `show`, `schedule` WHERE `channel` = 1 AND `start_time` <= UNIX_TIMESTAMP() AND `start_time` > UNIX_TIMESTAMP()-1800 AND `show`.`id` = `schedule`.`file` ORDER BY `start_time` DESC LIMIT 1</code>
Pertanyaan ini cuba mendapatkan semula item berjadual seterusnya untuk saluran tertentu, tetapi jika tiada baris yang sepadan ditemui, ia akan mengembalikan hasil kosong. Untuk mengembalikan nilai lalai, anda boleh menggunakan fungsi COALESCE atau IFNULL:
<code class="sql">SELECT COALESCE(`file`, 'default.webm') `file` ... SELECT IFNULL(`file`, 'default.webm') `file` ...</code>
Walau bagaimanapun, penyelesaian ini mungkin mengembalikan hasil kosong jika tiada baris ditemui. Untuk memastikan bahawa nilai lalai sentiasa dikembalikan, anda boleh menggunakan fungsi agregat, seperti MIN(), untuk memberikan nilai NULL apabila tiada rekod dipilih. Pernyataan berikut menggunakan teknik ini:
<code class="sql">SELECT IFNULL(MIN(`file`), 'default.webm') `file` ...</code>
Dengan menggunakan fungsi MIN(), anda boleh menjamin bahawa NULL akan dikembalikan jika tiada baris dipilih. Kemudian, fungsi IFNULL() akan menggantikan nilai NULL dengan nilai lalai, memastikan sesuatu sentiasa dipaparkan.
Atas ialah kandungan terperinci Bagaimana untuk Mengembalikan Nilai Lalai Apabila Pertanyaan SQL Tidak Mengembalikan Baris?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!