0

这是我的桌子

+----+---------------+-------+
| id | product name  | cat   |
+----+---------------+-------+
| 0  | product A     | 1     |
| 1  | product B     | 2     |
| 2  | product C     | 1     |
| 3  | product D     | 3     |
+----+---------------+-------+

我想要实现的输出是:

产品A
产品C
产品B
产品D

这是我正在使用的查询:

SELECT * FROM products GROUP BY cat ORDER BY id ASC

现在我对 MySQL 非常缺乏经验,简而言之,我正在尝试对我的结果进行分组,并在他们的组中对它们进行排序。

上面的查询(逐字)给了我一个语法错误。

经过一番研究,(看到一些类似问题的帖子)我想我可能需要使用 JOIN 来完成这个功能。但我不知道从哪里开始。

有人可以帮忙吗?

4

2 回答 2

1

不确定你需要在这里分组。试试这个:

SELECT * from products ORDER BY cat ASC, id ASC

这首先按 cat 排序,然后按 id 排序。请注意,您应该在 cat 字段上有一个索引来优化此查询(我已经假设 id 是主键)。

于 2012-08-03T15:49:46.517 回答
-1

在我看来,你需要

SELECT * FROM products ORDER BY cat ASC

得到你正在寻找的输出。

于 2012-08-03T15:50:33.497 回答