我有一个表number_color_style,其结构如下所示。

此表包含如下所示的数据(8行)

在输出时,我想要的是按number_color_id、number_style_id分组的所有记录。
我试过以下查询
SELECT *
FROM `number_color_style`
GROUP BY `number_color_id` , `number_style_id`它给了我输出,但是缺少了一些行。

我想要的是四组数据,而不缺少一行(应该包含所有8行)。例:
number_color_id = 1,number_style_id = 1number_color_id = 1,number_style_id = 2number_color_id = 2,number_style_id = 1number_color_id = 2,number_style_id = 2我该怎么做呢?
创建表查询
CREATE TABLE IF NOT EXISTS `number_color_style` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`img` varchar(100) NOT NULL,
`number_color_id` int(11) NOT NULL,
`number_style_id` int(11) NOT NULL,
`number_id` int(11) NOT NULL,
PRIMARY KEY (`id`)
);一些样本数据
INSERT INTO `jink`.`number_color_style` (`id`, `img`, `number_color_id`, `number_style_id`, `number_id`) VALUES (NULL, 'img1.png', '1', '1', '10'), (NULL, 'img2.png', '1', '1', '10'), (NULL, 'img3.png', '1', '2', '10'), (NULL, 'img4.png', '2', '1', '10'), (NULL, 'img5.png', '2', '1', '10');发布于 2012-10-19 05:41:06
如果您想按照number_color_id和number_style_id显示所有8组,应该使用order而不是group。
SELECT *
FROM `number_color_style`
ORDER BY `number_color_id` , `number_style_id`发布于 2012-10-19 05:41:54
当使用“group by”(如count (*) )时,需要一个聚合函数。这可能是因为你混淆了“按组”和“按顺序”。
一个可能的查询是:
select number_color_id, number_style_id, count (*)
from number_color_style
group by number_color_id, number_style_id但我觉得你想
select *
from number_color_style
order by number_color_id, number_style_idhttps://stackoverflow.com/questions/12967982
复制相似问题