ThinkPHP数据查询去重distinct和group by方法
发表于:2021-12-30 10:25:59浏览:2238次
近期在做项目的时候,遇到数据表查询去重的要求,处理好之后,对ThinkPHP的去重方法有了更加准确的认识和体会。 两种去重方式:
1、利用distinct方法去重(去除重复数据)
$data=Db::name('Article')->Distinct(true)->field('descriprion')->order('description desc')->select();
2、利用group方法去重(合并重复字段)
$data=Db::name('Article')->group('id')->order('id desc')->select();
dump($data);
对于两种去重方式:
利用distinct去重、简单易用,但只能对于单一字段去重,并且最终的结果也仅为去重的字段,实际应用价值不是特别大,对于使用TP自带的paginate分页查询方式得到的记录总数和实际查询到的总数有出入。
利用group去重,最终的显示结果为所有字段,且对单一字段进行了去重操作,效果不错,推荐使用group by。
推荐文章
- window11系统,局域网无法访问本地php项目的解决方案
- 在PHP中判断文件是否被修改过
- thinkphp6 leftjoin联表查询时,子表有多条记录去重后获取子表的最新记录查询方法
- 推荐:腾讯开源的Markdown编辑器,轻量简洁、易扩展,开箱即用
- 前端:javascript浅拷贝与深拷贝的区别
- 12款开源JavaScript 流程图组件推荐
- 微信小程序wx.scanCode,扫描二维码或者条形码获取数据
- 微软推出电脑管家,干净无广告无弹窗,是时候卸载360安全卫士和腾讯电脑管了
- 开源的OA办公系统 — 勾股OA4.09.10 发布
- 如何给OA系统加上名字工号的水印?其实很简单,WEB前端就能实现添加水印