在MySQL 中將Null 欄位設定為零
此MySQL 查詢旨在從各種表中擷取數據,包括uc_orders (uo ) 表。但是,結果包含空字段,需要將其傳回為零。
要實現此目的,可以在子查詢中使用 IFNULL 函數:
SELECT uo.order_id, IFNULL(uo.order_total, 0) AS 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中文網其他相關文章!