问题描述
我有两张表,一张工资表income,消费表payment,需要SQL查询出某一个人在本月的消费余额。当消费表记录为空或者工资表记录为空时,两个sum()函数相减MySQL显示结果为空值。
问题原因
没有做判断空值的处理。
解决方法
1、先把两张表中的金额字段的默认值设为0。 2、在运算的时候使用ifnull()函数判断是否为空,为空的话设为0值。
SELECT
(
SELECT
ifnull(sum(in_amount), 0)
FROM
income
WHERE
userid = ''
AND DATE_FORMAT(in_date, '%Y%m') = DATE_FORMAT(CURDATE(), '%Y%m')
) - (
SELECT
ifnull(sum(pay_amount), 0)
FROM
payment
WHERE
userid = ''
AND DATE_FORMAT(pay_date, '%Y%m') = DATE_FORMAT(CURDATE(), '%Y%m')
) AS result;