免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3277 | 回复: 3
打印 上一主题 下一主题

count(*) 与 group by一起使用的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-08-17 02:47 |只看该作者 |倒序浏览
mysql> SELECT COUNT(*) FROM Bird GROUP BY name;
+---------+----------+
| COUNT(*) |
+---------+----------+
|         2 |
|        1 |
+---------+----------+
2 rows in set (0.00 sec)

但是我的原意是想计算出Bird这个表中不重复name的行的总数,期望输出如下
+---------+----------+
| COUNT(*) |
+---------+----------+
|         3 |
+---------+----------+
1 rows in set (0.00 sec)

尝试使用了子查询:
SELECT COUNT(*) AS `Count` FROM( SELECT * FROM Bird GROUP BY name) AS `Temp`
但是在数据量稍大的情况下查询效果实在是慢到不能接受了

请教一下大家这个要怎么写法?

论坛徽章:
0
2 [报告]
发表于 2008-08-17 10:54 |只看该作者
select count(distinct name) from Bird

论坛徽章:
0
3 [报告]
发表于 2008-08-17 13:48 |只看该作者
但是我还要加上其他的where查询条件的话好像就不行了
SELECT Count(distinct `Name`) FROM `db_live_channel` WHERE `Name` LIKE '%re%' GROUP BY `Name`

论坛徽章:
0
4 [报告]
发表于 2008-08-17 19:30 |只看该作者
SELECT Count(distinct `Name`) FROM `db_live_channel` GROUP BY `Name` HAVING `Name` LIKE '%re%'

不过就算能运行也没效率可言的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP