msyql单表统计查询疑难问题

沧海一声啸! Hadoop工程师  2013-01-21 09:20:00
数据库中有类似这么样的一张表
A(ID) B(手机IMEI) C(手机IP) D(手机软件)
1 L 1 Z
2 L 2 X
3 1 C
4 M 5 Z
5 M 5 H
6 5 I
....
大概9万多条记录,里面的值我用字母和数字简单的代替了。

上表中3行和6行分别应该是L和M但是没有存进去,我想通过这个表查到此表中到底有多少手机,每个手机都下载了哪些软件。
...全文
128 6 点赞 打赏 收藏 举报
写回复
6 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
WWWWA 2013-01-22
只有将空缺的内容补上再统计
  • 打赏
  • 举报
回复
wxx0801 2013-01-22
select B,count(1) ,GROUP_CONCAT(D) from talbe_name group by B
  • 打赏
  • 举报
回复
ACMAIN_CHM 2013-01-22
复制到EXCEL中, 然后在B列使用空白填充。 之后再统计。如果熟悉EXCEL,也就5分钟的事儿。
  • 打赏
  • 举报
回复
rucypli 2013-01-21
如果没有记录的手机不算一个 那么 select sum(case when B is null then 1 else 0 end) + count(distinct B)-1 from B
  • 打赏
  • 举报
回复
沧海一声啸! 2013-01-21
引用 1 楼 rucypli 的回复:
有多少个手机 select count(distinct B) from tb; 每个手机下载了多少个软件 select B,count(*) from tb group by B
select count(distinct B) from tb;这句得到的手机数不准确啊,没有数据的记录算一个手机?
  • 打赏
  • 举报
回复
rucypli 2013-01-21
有多少个手机 select count(distinct B) from tb; 每个手机下载了多少个软件 select B,count(*) from tb group by B
  • 打赏
  • 举报
回复
相关推荐
发帖
MySQL
加入

5.5w+

社区成员

MySQL相关内容讨论专区
申请成为版主
帖子事件
创建了帖子
2013-01-21 09:20
社区公告
暂无公告