首頁 > 資料庫 > mysql教程 > 如何在 MySQL 查詢中將 NULL 欄位替換為零?

如何在 MySQL 查詢中將 NULL 欄位替換為零?

Barbara Streisand
發布: 2025-01-04 16:33:46
原創
283 人瀏覽過

How Can I Replace NULL Fields with Zeros in MySQL Queries?

在 MySQL 中將空白欄位設為零

在 MySQL 中,處理空值通常是一個挑戰。查詢資料時,傳回非空值來取代空欄位可能很有用。在空值可能會影響計算或影響結果可讀性的情況下尤其如此。

要將空白欄位設為零,可以使用 IFNULL() 函數。 IFNULL() 採用兩個參數:要計算的表達式以及表達式為 null 時要傳回的值。例如:

IFNULL(expr1, 0)
登入後複製

如果 expr1 不為 null,則 IFNULL() 傳回 expr1。否則,它返回 0。這使您可以輕鬆地將空值替換為指定值,例如零。

在提供的查詢中,IFNULL() 可用於處理 products_subtotal、 payment_received 中的空值和 line_item_subtotal 欄位。以下是修改後的查詢:

SELECT uo.order_id, uo.order_total, uo.order_status,
            IFNULL((SELECT SUM(uop.price * uop.qty) 
             FROM uc_order_products uop 
             WHERE uo.order_id = uop.order_id
            ), 0) AS products_subtotal,
            IFNULL((SELECT SUM(upr.amount) 
             FROM uc_payment_receipts upr 
             WHERE uo.order_id = upr.order_id
            ), 0) AS payment_received,
            IFNULL((SELECT SUM(uoli.amount) 
             FROM uc_order_line_items uoli 
             WHERE uo.order_id = uoli.order_id
            ), 0) AS line_item_subtotal
            FROM uc_orders uo
            WHERE uo.order_status NOT IN ("future", "canceled")
            AND uo.uid = 4172;
登入後複製

透過合併 IFNULL(),查詢現在將為指定欄位中的任何空值傳回 0,確保結果一致且易於解釋。

以上是如何在 MySQL 查詢中將 NULL 欄位替換為零?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板