將 MySQL 中的空值歸零
在 MySQL 中,在資料庫欄位中遇到空值並不罕見。這些空值可能會擾亂計算,並使顯示乾淨、準確的數據變得困難。為了解決這個問題,MySQL 提供了 IFNULL() 函數,它使您能夠指定替代值來取代空值。
考慮以下場景:
SELECT uo.order_id, uo.order_total, uo.order_status, (SELECT SUM(uop.price * uop.qty) FROM uc_order_products uop WHERE uo.order_id = uop.order_id ) AS products_subtotal, (SELECT SUM(upr.amount) FROM uc_payment_receipts upr WHERE uo.order_id = upr.order_id ) AS payment_received, (SELECT SUM(uoli.amount) FROM uc_order_line_items uoli WHERE uo.order_id = uoli.order_id ) AS line_item_subtotal FROM uc_orders uo WHERE uo.order_status NOT IN ("future", "canceled") AND uo.uid = 4172;
此查詢擷取訂單來自各種表格的資訊。但是,某些欄位可能包含空值。要為這些字段返回0 而不是null,您可以使用IFNULL(),如下所示:
SELECT uo.order_id, IFNULL(uo.order_total, 0), uo.order_status, IFNULL(products_subtotal, 0), IFNULL(payment_received, 0), IFNULL(line_item_subtotal, 0) FROM uc_orders uo WHERE uo.order_status NOT IN ("future", "canceled") AND uo.uid = 4172;
在此修改後的查詢中,IFNULL() 應用於所有容易出現null 值的字段。它檢查該欄位是否不為空;如果是,則傳回實際值。否則,它返回 0。
此技術可確保所有檢索到的欄位都具有非空值,使資料更加一致且更易於使用。
以上是如何在 MySQL 查詢中用零取代 NULL 值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!