Thinkphp数据查询group分组如何取每组的最新记录
1个回答
展开全部
本人用ThinkPHP3.2,今天正在开发一个需要分组显示的功能,可是从数据库中把相应数据读取后直接用group分组,结果每组显示的是最老的记录,我的需求是要显示每组的最新记录。在网上大搜一翻后,未果,本人决定自行研究,现将方法记录于此以防遗忘。
其实很简单,以供就两步:
第一步:
将符合条件的数据全部取出,暂不用group分组,作为子查询:
[php] view plain copy
$subQuery = $model->field('id,name')->table('tablename')->where($where)->order('time desc')->select(false);
$model->table($subQuery.' a')->group('field')->select();<span style="font-family: Arial, Helvetica, sans-serif;"> </span>
第二部:
利用子查询进行查询分组
[php] view plain copy
好了,思路就是这样。希望对大家有帮助!
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询