首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL一次查询多个计数

MySQL一次查询多个计数
EN

Stack Overflow用户
提问于 2020-09-16 20:36:08
回答 2查看 46关注 0票数 0

我尝试按月计算售出的数量,并得到一个数组。

代码语言:javascript
运行
复制
$q = SELECT COUNT(id) AS January FROM tableName WHERE status='sold' AND month = '1'
UNION 
SELECT COUNT(id) AS February FROM tableName WHERE status='sold' AND month = '2'

$row = mysqli_fetch_array(mysqli_query($connection, $q));

print_r($row);

UNION不工作,当我尝试print_r(数组)时,我得到结果

代码语言:javascript
运行
复制
[Jenuary] => 200

如何在两个月内获得一个数组?

我想要结果:

代码语言:javascript
运行
复制
[January] => 200,
[February] => 221
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-09-16 20:38:04

我认为您需要条件聚合:

代码语言:javascript
运行
复制
select sum(month = 1) as january, sum(month = 2) as february
from tablename
where status = 'sold' and month in (1, 2)

这只生成一行,其中有两列,分别名为januaryfebruary,每列都包含该月的行数。

或者,您可能希望每个月都有一行。在这种情况下,您可以使用简单的聚合:

代码语言:javascript
运行
复制
select month, count(*) cnt
from tablename
where status = 'sold' and month in (1, 2)
group by month
票数 1
EN

Stack Overflow用户

发布于 2020-09-16 21:07:52

您可以尝试此查询以获得所需的确切结果。

代码语言:javascript
运行
复制
select MONTHNAME(STR_TO_DATE(month, '%m')) as month, count(*) cnt
from tablename
where status = 'sold'
group by month

仅适用于特定月份

代码语言:javascript
运行
复制
 select MONTHNAME(STR_TO_DATE(month, '%m')) as month, count(*) cnt
    from tablename
    where status = 'sold' and month in(1, 2)
    group by month
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63920234

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档