ThinkPHP数据查询去重distinct和group by方法
发表于:2021-12-30 10:25:59浏览:2464次
近期在做项目的时候,遇到数据表查询去重的要求,处理好之后,对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。
推荐文章
- Flash已退出历史舞台,未来Web端3D的内容会怎样发展?
- 微信H5版使用php Ffmpeg将微信录音amr转mp3
- Nginx + PHP 搭建的服务器发现POST数据无法提交或数据被截断的解决方案
- 勾股系列系统:项目任务协作管理系统 —— 勾股 DEV 3.8.31 发布
- 谷歌发布Flutter 3,增加对macOS和Linux 应用的支持
- 前端报错:was loaded over HTTPS, but requested an insecure错误解决方案
- Markdown编辑器Editor.md,实现粘贴图片上传,拖拽文件上传
- 前端开发简单吗?一套前端的知识体系带你了解前端岗位
- PHP中如何将数组转换为JSON格式数据
- centos系统,宝塔面板SSL证书文件在哪里?