Thinkphp数据查询group分组如何取每组的最新记录

 我来答
从空去听8
2017-11-28 · TA获得超过7439个赞
知道大有可为答主
回答量:6907
采纳率:93%
帮助的人:5500万
展开全部

本人用ThinkPHP3.2,今天正在开发一个需要分组显示的功能,可是从数据库中把相应数据读取后直接用group分组,结果每组显示的是最老的记录,我的需求是要显示每组的最新记录。在网上大搜一翻后,未果,本人决定自行研究,现将方法记录于此以防遗忘。

其实很简单,以供就两步:

第一步:

将符合条件的数据全部取出,暂不用group分组,作为子查询:

[php] view plain copy

  • $subQuery = $model->field('id,name')->table('tablename')->where($where)->order('time desc')->select(false);  


  • 第二部:

    利用子查询进行查询分组

    [php] view plain copy

  • $model->table($subQuery.' a')->group('field')->select();<span style="font-family: Arial, Helvetica, sans-serif;"> </span>  


  • 好了,思路就是这样。希望对大家有帮助!

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式