免费注册 查看新帖 |

Chinaunix

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

求教 : 关于下面的 SQL 语句应该怎么写的? [复制链接]

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-04-24 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-06-15 11:55 |只看该作者 |倒序浏览
本帖最后由 jiangling_0103 于 2016-06-15 12:02 编辑

我使用下面的语句可以查询出某个项目中Bug 对应的状态的数量,

select bug_status Name , COUNT(*) Count from bugs INNER JOIN products p ON bugs.product_id=p.id WHERE p.name = 'SC7702' GROUP BY bug_status WITH ROLLUP;




如果我想再加一列 Percentage 对应各个状态的Bug占总数的百分比的,如下图的,SQL语句应该怎么写合适的?求教啊~

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
2 [报告]
发表于 2016-06-17 13:27 |只看该作者
回复 1# jiangling_0103


    这个情况我是先算一个所有的 COUNT(*) 赋值给临时变量,然后再计算。分两条 select 操作。

论坛徽章:
223
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-05-10 19:22:58操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:10操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
3 [报告]
发表于 2016-06-18 00:54 来自手机 |只看该作者
存储过程可以的

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-06-11 06:20:00
4 [报告]
发表于 2016-06-29 14:20 |只看该作者
select bug_status Name , COUNT(*) Count,Count(*)/(select count(*) from bugs INNER JOIN products p ON bugs.product_id=p.id WHERE p.name = 'SC7702' GROUP BY bug_status WITH ROLLUP) as per from bugs INNER JOIN products p ON bugs.product_id=p.id WHERE p.name = 'SC7702' GROUP BY bug_status WITH ROLLUP;

大概可以这样,效率可能低点,具体debug一下

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
5 [报告]
发表于 2016-06-30 13:24 |只看该作者
  1. mysql> select * from tb1;
  2. +----+-------+
  3. | id | name  |
  4. +----+-------+
  5. |  1 | aaaaa |
  6. |  2 | aaabb |
  7. |  3 | aabbc |
  8. |  4 | bbbbb |
  9. |  5 | ddddd |
  10. +----+-------+
  11. 5 rows in set

  12. mysql> select name, count(id), count(id) / (select count(*) as total from tb1) from tb1 as t group by name;
  13. +-------+-----------+-------------------------------------------------+
  14. | name  | count(id) | count(id) / (select count(*) as total from tb1) |
  15. +-------+-----------+-------------------------------------------------+
  16. | aaaaa |         1 | 0.2000                                          |
  17. | aaabb |         1 | 0.2000                                          |
  18. | aabbc |         1 | 0.2000                                          |
  19. | bbbbb |         1 | 0.2000                                          |
  20. | ddddd |         1 | 0.2000                                          |
  21. +-------+-----------+-------------------------------------------------+
  22. 5 rows in set

  23. mysql> select name, count(id), count(id) / total from tb1, (select count(*) as total from tb1) as t group by name;
  24. +-------+-----------+-------------------+
  25. | name  | count(id) | count(id) / total |
  26. +-------+-----------+-------------------+
  27. | aaaaa |         1 | 0.2000            |
  28. | aaabb |         1 | 0.2000            |
  29. | aabbc |         1 | 0.2000            |
  30. | bbbbb |         1 | 0.2000            |
  31. | ddddd |         1 | 0.2000            |
  32. +-------+-----------+-------------------+
  33. 5 rows in set
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP