Rumah  >  Soal Jawab  >  teks badan

mysql group by 不能排序问题

我现在有一个文章表 有两个字段 id 和 catid
我想给 每个catid 有8个分类 列出 最新发的一篇文章

select * from post gruop by catid order by id desc;

这样我只能取出 8条 id 最小的 也就是 最老的一篇文章 order by id 并不起作用

如何才能按照id号desc开始排序

PHPzPHPz2742 hari yang lalu1082

membalas semua(3)saya akan balas

  • 阿神

    阿神2017-04-17 16:54:09

    你select * 本来就是不严谨的写法,只是mysql兼容性比较强默认给你放最小的,如果sql带有group by,那么select里头只能包含group by中的列或者是聚合函数,你评论说的没法order by 是因为需要对max后的列加一个别名。

    select max(id) id, catid from post group by catid order by id desc;

    balas
    0
  • 高洛峰

    高洛峰2017-04-17 16:54:09

    select * from post gruop by catid order by id desc;

    balas
    0
  • PHP中文网

    PHP中文网2017-04-17 16:54:09

    gruop by catid 写在后面

    balas
    0
  • Batalbalas