Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/bash/18.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql 有附加分组的分组?_Mysql_Group Concat - Fatal编程技术网

Mysql 有附加分组的分组?

Mysql 有附加分组的分组?,mysql,group-concat,Mysql,Group Concat,我已经开始编写一个脚本,用它来统计调用特定文章的频率和时间 SELECT `title`, `page_id`, COUNT(*) AS `total`, GROUP_CONCAT(DISTINCT `date_created` ORDER BY `date_created` SEPARATOR ',') dates FROM `statistics` WHERE `supplier_id` = '27' GROUP BY `title` ORDER BY

我已经开始编写一个脚本,用它来统计调用特定文章的频率和时间

SELECT `title`, `page_id`, COUNT(*) AS `total`, 
GROUP_CONCAT(DISTINCT `date_created` 
             ORDER BY `date_created` SEPARATOR ',') dates 
FROM `statistics` 
WHERE `supplier_id` = '27' 
GROUP BY `title` 
ORDER BY `title`;
产生

[0] => Array
        (
            [0] => Array
                (
                    [total] => 3
                    [dates] => 2011-04-26,2011-04-27
                )

            [statistics] => Array
                (
                    [title] => Title 2
                    [page_id] => 2
                )  
        )

[1] => Array
        (
            [0] => Array
                (
                    [total] => 6
                    [dates] => 2011-04-26,2011-04-27,2011-04-28
                )

            [statistics] => Array
                (
                    [title] => Title 7
                    [page_id] => 7
                )
        )
好东西。但我如何添加一个类似于dates的字段,该字段添加按date_创建的ID分组的细分,从而创建如下内容:

[2] => Array
    (
        [0] => Array
            (
                [total] => 6
                [dates] => 2011-04-26,2011-04-27,2011-04-28
                [total_by_date] => 2,1,3
            )

        [statistics] => Array
            (
                [title] => Title 7
                [page_id] => 7
            )
)
我想通过以下方式添加一个额外的组:

GROUP_CONCAT(DISTINCT COUNT(*) AS `total_by_date` 
             GROUP BY `date_created` ORDER BY `date_created` SEPARATOR ',')
但它不起作用,我该怎么解决

转储:


不是100%确定这会起作用,但这是一个开始:

在子查询中执行第二个
组\u CONCAT

SELECT title
  , s1.page_id
  , s2.total_by_date
  , GROUP_CONCAT(DISTINCT s1.date_created
                 ORDER BY s1.date_created SEPARATOR ',') as dates  
FROM statistics s1
INNER JOIN  
  (SELECT page_id
     ,GROUP_CONCAT(/*DISTINCT*/ gc.cnt
     ORDER BY gc.date_created SEPARATOR ',') AS total_by_date
   FROM 
   (
      SELECT count(*) as cnt
        ,date_created
      FROM statistics
      WHERE supplier_id = '27'
      GROUP BY date_created
   ) gc
   GROUP BY gc.date_created
  ) s2 ON (s1.page_id = s2.page_id)      
WHERE supplier_id = '27'  
GROUP BY title  
ORDER BY title; 
使用distinct count(*)将隐藏具有相同计数的项目,这不是我认为您想要的,因此我将其放在注释形式中。

顺便说一句,
按标题排序
在这里不需要,因为
按标题分组
已经按标题排序了。

谢谢Johan的回复。不幸的是,它似乎不喜欢组中的计数(*)。有什么办法吗?我收到一个1111:组函数无效使用错误。仍然收到一个“1111:组函数无效使用”错误。奇怪的是,我确信我过去曾在GROUP_CONCAT中使用COUNT……尽管这是一个更简单的查询;-)@塔夫,对不起,我没主意了,你能用create和insert语句更新你的问题帖子吗?更新的问题-添加了一个转储。干杯,塔夫
SELECT title
  , s1.page_id
  , s2.total_by_date
  , GROUP_CONCAT(DISTINCT s1.date_created
                 ORDER BY s1.date_created SEPARATOR ',') as dates  
FROM statistics s1
INNER JOIN  
  (SELECT page_id
     ,GROUP_CONCAT(/*DISTINCT*/ gc.cnt
     ORDER BY gc.date_created SEPARATOR ',') AS total_by_date
   FROM 
   (
      SELECT count(*) as cnt
        ,date_created
      FROM statistics
      WHERE supplier_id = '27'
      GROUP BY date_created
   ) gc
   GROUP BY gc.date_created
  ) s2 ON (s1.page_id = s2.page_id)      
WHERE supplier_id = '27'  
GROUP BY title  
ORDER BY title;