SELECT COUNT(wash) AS HandHyCounts, COUNT(enex) AS EnExCounts,
(COUNT(wash)*100/COUNT(enex)) AS Performance, DATE_FORMAT(time, ?) AS groups
FROM ((SELECT true AS enex, null AS wash, time FROM enexlive
WHERE time >= ? AND time <= ? AND unitid IN (?))
UNION ALL
(SELECT null AS enex, true AS wash, time
FROM washtablelive WHERE time >= ? AND time <= ? AND unitid IN (?))) AS t1
GROUP BY groups ORDER BY groups;
MySQL是否可以为未出现在数据库表中的Date_Format返回0计数?
示例:假设您将日期格式设置为%m-%d-%k,因此它显示月 - 日 - 小时以及您在2月26日下午1点到2月27日下午1点之间查找时间戳的数据。但2月27日凌晨5点到2点27点之间没有数据。
SELECT COUNT(wash) AS HandHyCounts, COUNT(enex) AS EnExCounts,
(COUNT(wash)*100/COUNT(enex)) AS Performance, DATE_FORMAT(time, '%m-%d-%k') AS groups
FROM ((SELECT true AS enex, null AS wash, time FROM enexlive
WHERE time >= '2013-02-26 13:50:33' AND time <= '2013-02-27 13:50:33' AND unitid IN ('6'))
UNION ALL
(SELECT null AS enex, true AS wash, time
FROM washtablelive WHERE time >= '2013-02-26 13:50:33' AND time <= '2013-02-27 13:50:33' AND unitid IN ('6'))) AS t1
GROUP BY groups ORDER BY groups;
这就是我得到的:
+--------------+------------+-------------+----------+
| HandHyCounts | EnExCounts | Performance | groups |
+--------------+------------+-------------+----------+
| 12 | 47 | 25.5319 | 02-26-13 |
| 87 | 268 | 32.4627 | 02-26-14 |
| 80 | 261 | 30.6513 | 02-26-15 |
| 71 | 275 | 25.8182 | 02-26-16 |
| 71 | 270 | 26.2963 | 02-26-17 |
| 58 | 154 | 37.6623 | 02-26-18 |
| 45 | 141 | 31.9149 | 02-26-19 |
| 53 | 281 | 18.8612 | 02-26-20 |
| 44 | 175 | 25.1429 | 02-26-21 |
| 29 | 140 | 20.7143 | 02-26-22 |
| 22 | 107 | 20.5607 | 02-26-23 |
| 26 | 139 | 18.7050 | 02-27-0 |
| 23 | 56 | 41.0714 | 02-27-1 |
| 23 | 154 | 14.9351 | 02-27-2 |
| 18 | 144 | 12.5000 | 02-27-3 |
| 19 | 93 | 20.4301 | 02-27-4 |
+--------------+------------+-------------+----------+
这就是我想要的:
+--------------+------------+-------------+----------+
| HandHyCounts | EnExCounts | Performance | groups |
+--------------+------------+-------------+----------+
| 12 | 47 | 25.5319 | 02-26-13 |
| 87 | 268 | 32.4627 | 02-26-14 |
| 80 | 261 | 30.6513 | 02-26-15 |
| 71 | 275 | 25.8182 | 02-26-16 |
| 71 | 270 | 26.2963 | 02-26-17 |
| 58 | 154 | 37.6623 | 02-26-18 |
| 45 | 141 | 31.9149 | 02-26-19 |
| 53 | 281 | 18.8612 | 02-26-20 |
| 44 | 175 | 25.1429 | 02-26-21 |
| 29 | 140 | 20.7143 | 02-26-22 |
| 22 | 107 | 20.5607 | 02-26-23 |
| 26 | 139 | 18.7050 | 02-27-0 |
| 23 | 56 | 41.0714 | 02-27-1 |
| 23 | 154 | 14.9351 | 02-27-2 |
| 18 | 144 | 12.5000 | 02-27-3 |
| 19 | 93 | 20.4301 | 02-27-4 |
| 0 | 0 | NULL | 02-27-5 |
| 0 | 0 | NULL | 02-27-6 |
| 0 | 0 | NULL | 02-27-7 |
| 0 | 0 | NULL | 02-27-8 |
| 0 | 0 | NULL | 02-27-9 |
| 0 | 0 | NULL | 02-27-10 |
| 0 | 0 | NULL | 02-27-11 |
| 0 | 0 | NULL | 02-27-12 |
+--------------+------------+-------------+----------+
答案 0 :(得分:1)
是。但这个答案太短了。
count()
总是返回一个值,而不是NULL
。您可以使用简单查询对此进行验证,例如:
select count(*)
from information_schema.columns
where 1 = 0;
这会返回0
,而不是NULL
。
我很确定这是符合ANSI标准的行为。
另一方面,您有count()
个值的分区。在这种情况下,MySQL为NULL
返回0/0
而不是生成错误(其他数据库可能会这样做)。您也可以轻松地将其模仿为:
select count(table_name) / count(*)
from information_schema.columns
where 1 = 0;
这将返回一行,其中一列的值为NULL
。