mysql 一条语句多种count如何写
PHPz
PHPz 2017-04-17 15:01:50
[MySQL讨论组]

现在的统计是这样写的

select column1 title,count(1) count1
FROM table1
WHERE column2 is not null
AND column2 > '2016-06-13'
AND column2 < '2016-06-28'
AND column3 is not null
group BY title
having count1 > 3000

现在要再加一列统计,数据是在这个基础上再加一个条件过滤,
大概就是要下面这样的效果,要怎么写?

select column1 title,count(1) count1,count(column3='abc') count2
FROM table1
WHERE column2 is not null
AND column2 > '2016-06-13'
AND column2 < '2016-06-28'
AND column3 is not null
group BY title
having count1 > 3000
PHPz
PHPz

学习是最好的投资!

全部回复(2)
伊谢尔伦
select column1 title,count(1) count1, sum(IF(column3='abc', 1, 0)) count2
FROM table1
WHERE 
column2 > '2016-06-13'
AND column2 < '2016-06-28'
AND column3 is not null
group BY title
having count1 > 3000

试试看
条件中的column2 is not null没用,可以去掉。

大家讲道理

楼上正解,也可以试试这个,结果是一样的

select column1 title,count(1) count1,count(column3='abc' or null) count2
FROM table1
WHERE column2 between '2016-06-14' and '2016-06-27'
AND column3 is not null
group BY title
having count(1) > 3000  -- 用别名count1会报错的,这里不能用别名
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号