0

0

PHP中ThinkPHP的高级查询

冷炫風刃

冷炫風刃

发布时间:2025-12-05 14:14:00

|

188人浏览过

|

来源于php中文网

原创

ThinkPHP高级查询支持多表关联、闭包动态条件、子查询及聚合统计。通过join链式调用实现灵活关联;闭包where按需拼接防SQL注入;子查询支持in/exist;group+聚合函数满足报表需求。

php中thinkphp的高级查询

ThinkPHP 的高级查询主要体现在对复杂业务场景的支持上,比如多表关联、子查询、聚合统计、动态条件拼接、闭包查询等。掌握这些能力,能显著减少 SQL 硬编码,提升可维护性和安全性。

多表关联与 JOIN 查询

ThinkPHP 支持链式调用的 join 方法,可灵活处理 inner、left、right 等连接方式。注意关联字段需显式指定别名或使用完整表名前缀,避免字段冲突。

  • 使用 join('table2', 'table1.id=table2.uid') 显式写连接条件
  • 配合 field() 精确选择字段,如 field('user.name,order.amount')
  • 多个 join 可连续调用,顺序影响执行逻辑,建议 left join 在前,inner join 在后

闭包查询与动态条件组装

闭包是 ThinkPHP 实现“按需拼接 where 条件”的核心机制,特别适合搜索页、后台筛选等不确定查询参数的场景。

  • where 方法接受闭包: where(function ($query) use ($status, $keyword) { if ($status) $query->where('status', $status); if ($keyword) $query->where('title', 'like', "%$keyword%"); })
  • 闭包内可嵌套 orWhere、whereIn、between 等,保持逻辑清晰
  • 避免在闭包外直接拼接字符串条件,防止 SQL 注入

子查询与 EXISTS/IN 高级用法

ThinkPHP 允许将 Query 对象作为值传入 where,自动转为子查询。适用于“查出满足某子集条件的主记录”类需求。

聚彩手机网店系统 免费版
聚彩手机网店系统 免费版

聚彩手机商城系统,是一款专业于手机销售的独立手机网店系统,他拥有众多的手机参数选项,以及傻瓜式的设置选项,让您可以在5分钟内建立起专业而强大的手机销售网站。他拥有多套模版可以实时切换,前台拥有新闻中心、手机中心、配件中心、软件下载、手机报价、发货查询、保修查询、分店查询、产品的对比功能,代理与加盟的申请等功能,他拥有完善的会员中心,会员等级设置等,集成在线支付接口,超强SEO,可以设置所有页面的t

下载

立即学习PHP免费学习笔记(深入)”;

  • 构造子查询对象:$subQuery = Db::name('order')->where('status', 1)->field('user_id');
  • 用于 in 查询:where('id', 'in', $subQuery)
  • 用于 exists:whereExists($subQuery->whereRaw('user.id = order.user_id'))
  • 子查询中慎用 limit,部分数据库不支持带 limit 的子查询

聚合查询与分组统计

count、sum、avg 等聚合方法可直接链式调用,配合 group 和 having 实现报表级查询。

  • Db::name('order')->group('user_id')->sum('amount') 返回各用户的金额总和数组
  • having 必须配合 group 使用,例如 having('sum(amount)', '>', 1000)
  • 若需同时查字段和聚合值,用 field() 显式声明,如 field('user_id, sum(amount) as total')
  • distinct 去重可结合 count 使用:count('DISTINCT user_id')

基本上就这些。用好闭包、子查询和关联,再配合合理的模型定义,ThinkPHP 的查询就能覆盖绝大多数业务需求,既安全又不失灵活性。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2629

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1629

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1511

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1418

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.5万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号