ThinkPHP有5种核心查询方式:1.基础链式查询,2.原生SQL查询,3.视图查询,4.关联查询(含预加载),5.查询作用域;其中链式+关联+作用域覆盖90%以上需求。

ThinkPHP 的查询方式主要围绕模型(Model)和查询构建器(Query Builder)展开,常见且实用的有 5 种核心查询类型,对应不同场景下的数据获取需求。
通过模型调用链式方法组合条件,最终用 select() 或 find() 执行:
UserModel::where('status', 1)->order('id desc')->limit(10)->select() —— 查多条UserModel::where('id', 10)->find() —— 查单条(主键查询可简写为 find(10))特点是灵活、可读性强,适合大多数业务逻辑。
当链式方法难以表达复杂逻辑(如子查询、特定函数、联合查询)时,直接执行原生语句:
立即学习“PHP免费学习笔记(深入)”;
Db::query("SELECT * FROM user WHERE status = ? AND create_time > ?", [1, '2024-01-01']) —— 查询语句,返回数组Db::execute("UPDATE user SET status = ? WHERE id = ?", [0, 5]) —— 执行增删改注意使用参数绑定防止 SQL 注入,避免拼接变量。
针对数据库视图或临时表结构,可新建模型指向视图名(如 OrderSummary 对应视图 view_order_summary),然后像普通模型一样链式查询:
OrderSummary::where('year', 2024)->select()前提是数据库已创建好视图,ThinkPHP 不负责建视图,只做查询封装。
用于处理一对多、多对一等关系,减少 N+1 查询问题:
ArticleModel::with('author,category')->select() —— 预加载关联模型ArticleModel::has('comments', 'count>3')->select() —— 按关联存在/数量筛选belongsTo/hasMany 方法后,支持 $article->author 延迟加载
合理使用 with() 能显著提升列表页性能。
把常用查询条件抽象成作用域方法,提高代码复用性:
public function scopeActive($query) { return $query->where('status', 1); }
UserModel::active()->select()
适合多处用到相同过滤逻辑的场景,比如“启用状态”、“未删除”、“本月数据”等。
基本上就这些。实际开发中,链式查询 + 关联查询 + 作用域 组合覆盖了 90% 以上的查询需求;原生 SQL 和视图查询按需补充。不复杂但容易忽略的是:链式方法顺序不影响结果,但 where 必须在 select 前,且每次调用都会新建查询实例(非单例)。
以上就是PHP之ThinkPHP有几种查询?的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号