mysql中sum()函数相减结果为空的处理

问题描述

我有两张表,一张工资表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;
相关文章
相关标签/搜索