J'ai commencé sur un script pour générer des statistiques de la fréquence et quand un article particulier est appelé en utilisantGROUP_CONCAT avec groupement supplémentaire?
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`;
qui produit
[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
)
)
Good stuff. Mais comment puis-je ajouter un domaine similaire à des dates qui ajoute une répartition des ids groupées par date_created créant ainsi quelque chose comme:
[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
)
)
Je voudrais ajouter un groupe supplémentaire en le long de ces lignes:
GROUP_CONCAT(DISTINCT COUNT(*) AS `total_by_date`
GROUP BY `date_created` ORDER BY `date_created` SEPARATOR ',')
mais ça ne marche pas, comment résoudre ce problème?
DÉCHARGE:
CREATE TABLE `statistics` (
`id` int(11) NOT NULL auto_increment,
`pagetype` varchar(50) character set utf8 collate utf8_unicode_ci NOT NULL,
`supplier_id` int(11) NOT NULL,
`page_id` int(11) default NULL,
`title` varchar(255) character set utf8 collate utf8_unicode_ci NOT NULL,
`date_created` date NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=920 ;
--
-- Dumping data for table `statistics`
--
INSERT INTO `statistics` (`id`, `pagetype`, `supplier_id`, `page_id`, `title`, `date_created`) VALUES
(1, 'newsarticle', 27, 2751, 'Title 1', '2011-04-26'),
(2, 'newsarticle', 27, 2751, 'Title 1', '2011-04-26'),
(3, 'newsarticle', 27, 2751, 'Title 1', '2011-04-27'),
(4, 'newsarticle', 27, 462009, 'Title 2', '2011-04-26'),
(5, 'newsarticle', 27, 462009, 'Title 2', '2011-04-26'),
(6, 'newsarticle', 27, 462009, 'Title 2', '2011-04-27'),
(7, 'newsarticle', 27, 462009, 'Title 2', '2011-04-27'),
(8, 'newsarticle', 27, 462009, 'Title 2', '2011-04-27'),
(9, 'newsarticle', 27, 462009, 'Title 2', '2011-04-28'),
(10, 'newsarticle', 27, 46200, 'Title 3', '2011-04-26'),
(11, 'newsarticle', 27, 46200, 'Title 3', '2011-04-26'),
(12, 'newsarticle', 27, 46200, 'Title 3', '2011-04-26'),
(13, 'newsarticle', 27, 46200, 'Title 3', '2011-04-26'),
(14, 'newsarticle', 27, 46200, 'Title 3', '2011-04-26');
Pourriez-vous mettre à jour votre question en affichant un petit vidage avec create et quelques instructions insert? –
Question mise à jour - a ajouté un vidage. Cheers, Taff – Taff