当前位置:首页 > AI技术 > 正文内容

Think怎么使用模型字段延迟加载开关 Think手动控制是否触发关联教程完全指南|Duuu笔记

admin7天前AI技术15

ThinkPHP模型需用field()显式指定字段关闭自动加载,关联查询需用hasWhere()实现主表过滤,$lazy=false仅禁用未with的隐式关联触发。

ThinkPHP 模型中如何关闭字段自动加载

默认情况下,ThinkPHP 的模型会把所有字段都查出来,哪怕你只想要

id

name

。这不是性能问题,是设计逻辑问题——它不区分“需要的字段”和“定义的字段”。想关掉?不能靠配置项全局关,得在查询时手动指定。

field()

显式声明要查的字段,比如

$user->field('id,name')->find(1)

,没列进去的字段不会出现在结果里,也不会被赋值到模型属性中

如果用了

with()

关联,

field()

只影响主表,关联表字段仍按关联定义加载;想控制关联字段,得进关联方法里改

field()

别用

hidden

visible

属性替代——那只是序列化时过滤,数据库照样全查,内存里也照存

ThinkPHP 关联查询时怎么阻止自动触发

调用

$user->posts

这种属性访问,会立刻触发关联查询,哪怕你后面根本没用到

posts

数据。这不是懒加载,是“伪懒加载”:只要访问就查,无法跳过。

真正能关掉的只有

with()

之外的隐式访问:给模型加

protected $lazy = false;

(TP6.1+),这样

$user->posts

不再自动查,但注意——这仅对“未显式 with 的关联”生效

已经写了

with('posts')

,那就一定会查,

$lazy = false

对它无效

如果你只是想“查但不立刻执行”,得用

load()

替代属性访问,比如

$user->load('posts')

,它返回模型本身,且可链式调用,但依然会触发查询

为什么 setAttr 不影响字段加载时机

有人试过在模型里重写

setAttr

或用

getAttr

拦截字段,发现完全没用——因为字段加载发生在数据从数据库取出、赋值给模型属性的阶段,远早于任何 getter/setter 调用。

setAttr

是给“写入时的数据处理”用的,比如加密、格式转换,跟“查哪些字段”无关

字段是否被加载,取决于查询构造器(

Query

)传了什么

field

参数,以及关联关系是否被标记为“需预载入”

想动态决定字段,得在调用前拼

field()

,而不是寄希望于模型内部钩子

TP6 中 with() 的 where 条件写在哪最容易踩坑

很多人以为

with(['posts' => function ($q) { $q->where('status', 1); }])

能过滤关联数据,结果发现主模型还是全量返回,只是关联数据少了——这没错,但容易误以为主表也被过滤了。

PHP免费学习笔记(深入)

”;

这个

where

只作用于关联表的

SELECT

,不影响主表查询条件,也不影响主模型实例数量

如果想让主表也受关联条件影响(比如只查有已发布文章的用户),必须用

hasWhere()

,例如

UserModel::hasWhere('posts', ['status' => 1])->select()

with()

+ 闭包里的

limit()

有效,但

order()

在部分版本中会被忽略,建议统一在关联定义里写

order()

延迟加载不是开关一按就完事,ThinkPHP 把“字段选择”“关联触发”“条件下推”拆成三套机制,各自生效时机不同。最常被忽略的是:你以为关掉了某个功能,其实只是换了个地方执行而已。

相关文章

神经网络分类总结

从网络性能角度可分为连续型与离散型网络、确定性与随机性网络。 从网络结构角度可为前向网络与反馈网络。 从学习方式角度可分为有导师学习网络和无导师学习网络。 按连续突触性...

推荐10个AI人工智能技术网站

除了研究和开发人工智能技术,OpenAI还积极参与人工智能伦理和安全的研究和探讨。 认为,人工智能技术的发展必须遵循伦理和法律的规范,以确保人工智能的应用不会对人类带来负面影响。...

跨平台机器学习:ML.NET架构及应用编程

平台上的一个机器学习框架,它提供了一套丰富的算法和工具,使得开发人员可以轻松地构建和部署机器学习模型。支持多种编程语言,包括等,这使得它成为跨平台机器学习的理想选择。的架构主要包括三个部分:数据读取、...

一文讲清神经网络、BP神经网络、深度学习的关系

人工神经网络中的顶级代表。往往说《神经网络》就是指《BP神经网络》。 大家研究着各种神经网络,研究得不亦乐乎, 来了两个家伙Romelhart 和Mcclelland,...

深入理解前端开发:Minimax视频生成黑科技:复杂动作模拟完全指南|Duuu笔记

为精准模拟复杂动作,需采用分帧提示词构建、骨骼关键点引导注入和多阶段动作蒸馏三法:一、将动作拆解为带空间姿态的关键帧序列并加物理约束;二、注入2D/3D关键点坐标锚定关节位置;三、通过粗生成→特征提取...

深入理解前端开发:零基础教程:怎么用 Gemini 自动生成短视频脚本与拍摄大纲完全指南|Duuu笔记

需明确输入指令、理解输出逻辑并合理拆解内容:一、构建含角色/任务/格式等要素的提示词;二、追加分镜与时间轴约束优化专业性;三、转译为带道具编号与颜色标记的执行清单;四、用Gemini校验注意力断点并迭...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。