2

我有一个包含 2 列“id”和“name”的表。id 是常规的自增索引,name 只是 varchar。

id  name
1  john
2  mary
3  pop
4  mary
5  john
6  michael
7  john
8  will

我想像这样对搜索结果进行排序

8  will
7  john
5  john
1  john
6  michael
4  mary
2  mary
3  pop

Id 是 DESC,但所有重复的名称都组合在一起。没关系,如果 ASC 更容易实现。如有必要,我可以在 PHP 中反转结果。

常规 ORDER BY name,id DESC 首先对所有名称进行排序,然后对 id 进行排序。那不是我想要的。我对名称的字母顺序不感兴趣。

我想要按 DESC 顺序排列的 id,如果有的话,按重复的名称分组。

ps我很抱歉这是一个重复的问题。

4

2 回答 2

3

如果我理解正确,您将需要一个临时表。

SELECT TableName.id, TableName.Name FROM TableName
INNER JOIN 
(
    SELECT Name, max(id) as maxid FROM TableName GROUP BY Name
) as tmp on tmp.Name = TableName.Name
ORDER BY maxid DESC, id DESC
于 2013-09-30T12:37:28.823 回答
0

在 mysql 中有一个 group by 子句,见select,在页面上搜索 group by。

页面上有例子

所以试试这个...

SELECT id, name FROM TableName
group BY name;

由于您的 ID 充当您的主键,您可能不需要告诉它按升序排序,但您可以添加

order by id

如果你愿意。

当然,group by 子句也可以添加 ASC 和 DESC 子句,因此如果需要,您应该按字母顺序获取它们。

虽然,那说只是使用

order by desc(name)

可能会给您类似的结果,您需要在数据集上对其进行测试。

请注意,这可能是一个非常昂贵的选择,因为它会尝试将所有内容分类到您需要的顺序中。因此,如果您希望将其用作其他选择的基础,您可以决定创建一个临时表,然后您可以直接选择该表,否则每次使用主表时可能会重新发生分组。一旦您的数据集变得相当大,这可能是您想要考虑的事情。大卫

于 2013-09-30T13:40:19.920 回答