我有两张表,一张工资表income,消费表payment,须要SQL查询出某一我的在本月的消费余额。当消费表记录为空或者工资表记录为空时,两个sum()函数相减MySQL显示结果为空值。函数
没有作判断空值的处理。code
一、先把两张表中的金额字段的默认值设为0。 二、在运算的时候使用ifnull()函数判断是否为空,为空的话设为0值。date
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;