Rumah > Artikel > pangkalan data > Penggunaan fungsi coalesce dalam sql
Fungsi COALESCE dalam SQL digunakan untuk mengendalikan nilai NULL, mengembalikan nilai bukan NULL pertama dalam senarai ungkapan, atau mengembalikan nilai lalai jika semua ungkapan adalah NULL. Ia digunakan terutamanya untuk menggantikan nilai NULL, menyediakan nilai lalai dan pemeriksaan bertingkat. Untuk menggantikan nilai NULL, gunakan COALESCE(expr1, expr2, ...). Untuk memberikan nilai lalai, gunakan COALESCE(expr1, expr2, ..., default_value). Untuk semakan melata, COALESCE(expr1, expr2, ...) boleh digunakan.
Penggunaan fungsi COALESCE dalam SQL
Fungsi COALESCE ialah fungsi yang biasa digunakan dalam SQL, digunakan untuk mengendalikan nilai NULL. Ia memerlukan berbilang ungkapan sebagai senarai parameter dan mengembalikan nilai bukan NULL yang pertama. Jika semua ungkapan adalah NULL, nilai lalai dikembalikan.
Syntax
COALESCE(expr1, expr2, ..., exprN, default_value)
其中:
expr1
, expr2
, ..., exprN
:要检查的表达式。default_value
:如果所有表达式都为 NULL,则返回的默认值(可选)。用法
COALESCE 函数主要用于处理以下场景:
示例
1. 替换 NULL 值
<code class="sql">SELECT COALESCE(name, 'Unknown') FROM users;</code>
这会将 name
列中的所有 NULL 值替换为字符串 "Unknown"。
2. 提供默认值
<code class="sql">SELECT COALESCE(age, 0) FROM users;</code>
这会在 age
列中将所有 NULL 值替换为数字 0。
3. 级联检查
<code class="sql">SELECT COALESCE(address, city, country) FROM users;</code>
这会首先检查 address
列中的值。如果 address
为 NULL,它会检查 city
列的值。如果 city
也为 NULL,则返回 country
列的值。
注意事项
default_value
expr1
, expr2
, ..., exprN
: Ungkapan yang akan disemak. 🎜default_value
: Nilai lalai dikembalikan jika semua ungkapan adalah NULL (pilihan). 🎜🎜🎜🎜Penggunaan🎜🎜🎜Fungsi COALESCE digunakan terutamanya untuk mengendalikan senario berikut: 🎜alamat
ialah NULL, ia menyemak nilai lajur city
. Jika city
juga NULL, mengembalikan nilai lajur country
. 🎜🎜🎜Nota🎜🎜default_value
disediakan, fungsi COALESCE mengembalikan NULL. 🎜🎜Atas ialah kandungan terperinci Penggunaan fungsi coalesce dalam sql. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!