mysql - 为什么我的 IfNull() 函数不起作用?
问题描述
SELECT
f.province AS loc,
IFNULL(COUNT(f.province), 0) AS count
FROM
project_name_data d
RIGHT JOIN full_province f ON (
TRIM(
REPLACE (
REPLACE (
SUBSTRING_INDEX(d.location, '|', 1),
'省',
''
),
'壮族',
''
)
) = f.province
)
GROUP BY
loc;
这是我的查询sql,full_province是一个包含中国所有省份的表,project_name_data指的是主要数据。现在我想计算每个省份有多少记录,对于没有任何记录的省份,给他们0。但是我的Sql只返回包含记录的省份。其中有一些错误吗?
举个不合时宜的例子:
-- main table
id location comment other columns
1 Los Angeles aaa ...
2 New York bbb ...
3 Cambridge ccc ...
4 Philadelphia ddd ...
5 New York eee ...
6 Cambridge fff ...
--full_province table
id location
1 Los Angeles
2 New York
3 Cambridge
4 Philadelphia
5 Beijing
6 Tokyo
7 Barcelona
8 Paris
9 Toronto
期望输出:
location count
1 Los Angeles 1
2 New York 2
3 Cambridge 2
4 Philadelphia 1
5 Beijing 0
6 Tokyo 0
7 Barcelona 0
8 Paris 0
9 Toronto 0
解决方案
IFNULL
可以删除,因为如果d.province
值 beNULL
COUNT
不会累积。将返回0
。
SELECT
f.province AS loc,
COUNT(d.province) AS count
FROM
project_name_data d
RIHGT JOIN full_province f ON (
TRIM(
REPLACE (
REPLACE (
SUBSTRING_INDEX(d.location, '|', 1),
'省',
''
),
'壮族',
''
)
) = f.province
)
GROUP BY f.province;
编辑
我看到你添加了一些示例数据。
你可以试试这个查询。
SELECT
f.location AS loc,
COUNT(d.location) AS CNT
FROM
project_name_data d
right JOIN full_province f
ON d.location= f.location
GROUP BY f.location
ORDER BY d.id desc
[结果]:
| loc | CNT |
|--------------|-----|
| Philadelphia | 1 |
| Cambridge | 2 |
| New York | 2 |
| Los Angeles | 1 |
| Beijing | 0 |
| Barcelona | 0 |
| Toronto | 0 |
| Tokyo | 0 |
| Paris | 0 |
推荐阅读
- sql-server - 如何在 SQL 中实现 for each 循环
- c# - 对象池机制的问题,包含池的队列不能是静态的,因为静态变量不是继承的
- excel - 如果 sheet2 row1 上的单元格与 sheet1 上的单元格匹配,则将行从表 2 复制到表 1 并循环下一行
- c++ - 决定每次使用哪个模板特化结构
- azure - 在 DataFactory 中,是否有使用 Web API 将数据加载到 Dynamics365 的解决方案?
- python - 为什么tensorflow操作会导致NaN?
- swift - 订阅返回 Void 而不是 AnyCancelable
- java - 在 Hibernate 中使用 Annotation 在集合级别急切加载
- php - PHP 中有没有办法存储通过 Windows PC 发送的打印作业?
- android - 如何随机 int [] 图像而不在 bindviewholder 中重复