PHP之ThinkPHP有几种查询?

冷炫風刃
发布: 2025-12-05 19:34:02
原创
199人浏览过
ThinkPHP有5种核心查询方式:1.基础链式查询,2.原生SQL查询,3.视图查询,4.关联查询(含预加载),5.查询作用域;其中链式+关联+作用域覆盖90%以上需求。

php之thinkphp有几种查询?

ThinkPHP 的查询方式主要围绕模型(Model)和查询构建器(Query Builder)展开,常见且实用的有 5 种核心查询类型,对应不同场景下的数据获取需求。

1. 基础链式查询(最常用)

通过模型调用链式方法组合条件,最终用 select()find() 执行:

  • UserModel::where('status', 1)->order('id desc')->limit(10)->select() —— 查多条
  • UserModel::where('id', 10)->find() —— 查单条(主键查询可简写为 find(10)

特点是灵活、可读性强,适合大多数业务逻辑。

2. 原生 SQL 查询

当链式方法难以表达复杂逻辑(如子查询、特定函数、联合查询)时,直接执行原生语句:

立即学习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 注入,避免拼接变量。

3. 视图查询(View Query)

针对数据库视图或临时表结构,可新建模型指向视图名(如 OrderSummary 对应视图 view_order_summary),然后像普通模型一样链式查询:

ChatDOC
ChatDOC

ChatDOC是一款基于chatgpt的文件阅读助手,可以快速从pdf中提取、定位和总结信息

ChatDOC 262
查看详情 ChatDOC
  • OrderSummary::where('year', 2024)->select()

前提是数据库已创建好视图,ThinkPHP 不负责建视图,只做查询封装。

4. 关联查询(含预加载与动态关联)

用于处理一对多、多对一等关系,减少 N+1 查询问题:

  • ArticleModel::with('author,category')->select() —— 预加载关联模型
  • ArticleModel::has('comments', 'count>3')->select() —— 按关联存在/数量筛选
  • 在模型中定义 belongsTo/hasMany 方法后,支持 $article->author 延迟加载

合理使用 with() 能显著提升列表页性能。

5. 查询作用域(Scope)封装复用条件

把常用查询条件抽象成作用域方法,提高代码复用性:

  • 在模型中定义:public function scopeActive($query) { return $query->where('status', 1); }
  • 调用:UserModel::active()->select()

适合多处用到相同过滤逻辑的场景,比如“启用状态”、“未删除”、“本月数据”等。

基本上就这些。实际开发中,链式查询 + 关联查询 + 作用域 组合覆盖了 90% 以上的查询需求;原生 SQL 和视图查询按需补充。不复杂但容易忽略的是:链式方法顺序不影响结果,但 where 必须在 select 前,且每次调用都会新建查询实例(非单例)。

以上就是PHP之ThinkPHP有几种查询?的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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