如何使用MySQL COALESCE() 函数与MySQL SUM() 函数自定义输出?
当MySQL SUM()函数得到一个没有值的列作为参数时,它将返回NULL而不是0作为输出。但是,如果我们想将此输出自定义为显示0,则可以使用MySQL COALESCE()函数,它接受两个参数,如果第一个参数为NULL,则返回第二个参数;否则,返回第一个参数。为了说明这一点,我们以“Tender”表为例,该表包含以下数据:
mysql> Select * from tender; +----+---------------+--------------+ | Sr | CompanyName | Tender_value | +----+---------------+--------------+ | 1 | Abc Corp. | 250.369003 | | 2 | Khaitan Corp. | 265.588989 | | 3 | Singla group. | 220.255997 | | 4 | Hero group. | 221.253006 | | 5 | Honda group | NULL | +----+---------------+--------------+ 5 rows in set (0.00 sec)
当我们尝试查找“Honda Group”报出的总投标价值时,MySQL SUM()函数返回NULL,因为它在该列中没有值。
mysql> Select SUM(Tender_value) From Tender Where CompanyName = 'Honda Group'; +-------------------+ | SUM(Tender_value) | +-------------------+ | NULL | +-------------------+ 1 row in set (0.00 sec)
但是,如果我们想将此输出从NULL自定义为0,则可以使用COALESCE函数与SUM()函数一起查找“Honda Group”报出的总投标价值。
mysql> Select COALESCE(SUM(Tender_value),0) From Tender Where CompanyName = 'Honda Group'; +-------------------------------+ | COALESCE(SUM(Tender_value),0) | +-------------------------------+ | 0.000000 | +-------------------------------+ 1 row in set (0.00 sec)
现在,当我们使用COALESCE函数与SUM()函数一起查找“Mohan”(“Name”列中不存在的姓名)键入的总页数时,MySQL SUM()函数返回0:
mysql> SELECT COALESCE(SUM(daily_typing_pages),0) FROM employee_tbl WHERE Name = ‘Mohan’; +-------------------------+ | SUM(daily_typing_pages) | +-------------------------+ | 0 | +-------------------------+ 1 row in set (0.00 sec)
从上面的结果集可以看出,如果列中没有值,无论其数据类型如何,MySQL SUM()函数都将返回NULL。
广告