总和计数为mysql中的一列

Posted

技术标签:

【中文标题】总和计数为mysql中的一列【英文标题】:sum count as a column in mysql 【发布时间】:2013-07-01 07:08:20 【问题描述】:

我有一张桌子:

id | type | subtype

如何创建查询以输出如下

type1 | subtype1 | count-subtype1 | count-type1
type1 | subtype2 | count-subtype2 | count-type1
type2 | subtype3 | count-subtype3 | count-type2
type2 | subtype4 | count-subtype4 | count-type2

即小计作为输出中的一列。

没有“与汇总”

【问题讨论】:

谢谢,@SQL.injection 的回答解决了这个问题 【参考方案1】:

要成功地 awnser 这个查询(这就是一些 awsers 失败的地方),你需要知道 roollup 做了什么。如果您不想执行“手动” sql 汇总,还有另一个答案可以解决您的查询。

您需要的是两个查询,一个用于计算类型中的子类型,另一个用于计算类型。

首先计算子类型(然后调用这个查询)。

select count(*) count_subtype, type, subtype from Foo group by type, subtype;

还有另一个查询来计算类型(我们称这个查询为 t)。

select count(*) count_type, type from Foo froup by type

现在你需要合并两个查询:

select t.type, s.subtype, s.count_subtype, t.conttype from
       (select count(*) count_subtype, type, subtype from Foo group by type, subtype) as s 
    join
       (select count(*) count_type, type from Foo froup by type) as t 
            on (t.type=s.type);

【讨论】:

【参考方案2】:

假设我有这样的表结构:

 CREATE TABLE `test` (
  `id` int(11) NOT NULL auto_increment,
  `type` varchar(128) default NULL,
  `subtype` varchar(128) default NULL,
  KEY `id` (`id`));

还有这个数据:

INSERT INTO `test` VALUES (1,'a','1'),(2,'a','2'),(3,'a','3'),(4,'a','4'),(5,'b','4'),
(6,'c','4'),(7,'c','1'),(8,'c','2'),(9,'c','2');

我可以这样做:

SELECT test.type, test.subtype, count(test.subtype) as countsubtype, testbytype.counttype
FROM (test)
LEFT JOIN (SELECT type, count(type) AS counttype FROM test group by type) AS testbytype ON test.type = testbytype.type
GROUP by type, subtype;

+------+---------+--------------+-----------+
| type | subtype | countsubtype | counttype |
+------+---------+--------------+-----------+
| a    | 1       |            1 |         4 |
| a    | 2       |            1 |         4 |
| a    | 3       |            1 |         4 |
| a    | 4       |            1 |         4 |
| b    | 4       |            1 |         1 |
| c    | 1       |            1 |         4 |
| c    | 2       |            2 |         4 |
| c    | 4       |            1 |         4 |
+------+---------+--------------+-----------+

【讨论】:

【参考方案3】:

查询:

SELECT type, subtype, sum(type), sum(subtype) from table_name GROUP BY id

【讨论】:

以上是关于总和计数为mysql中的一列的主要内容,如果未能解决你的问题,请参考以下文章

分析较大文件中的一列[重复]

来自两个不同表的Mysql计数和总和

excel如何自动统计一周的列计数总和?

从另一个表中选择 * 以及计数/总和

使用计数联合或使用总和连接 - MySQL

MySQL 上的左连接 + 计数 + 总和