Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mengembalikan Nilai Lalai Apabila Pertanyaan SQL Tidak Mengembalikan Baris?

Bagaimana untuk Mengembalikan Nilai Lalai Apabila Pertanyaan SQL Tidak Mengembalikan Baris?

Patricia Arquette
Lepaskan: 2024-10-29 08:52:30
asal
930 orang telah melayarinya

How to Return a Default Value When a SQL Query Returns No Rows?

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

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

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

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!

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