扫码关注官方订阅号
查询文章列表同时查询文章的作者信息,如何关联查询,我写了一个用1对1的关系在模型了,在视图中调用,虽然可行,但是出来查询语句很多条查询作者的语句,怎么一次查询出来
闭关修行中......
像下边这样的查询和遍历,如果返回10条article数据,则一共会执行11次SQL语句,第一条是一次性查询所有10条article数据,另外每次遍历都会执行一次获取相应author数据的SQL查询(原因是Eloquent默认为Lazy Loading,访问关系数据的时候才进行查询操作)。
article
SQL
author
Eloquent
Lazy Loading
$articles = App\Article::all(); foreach ($articles as $article) { echo $article->author->name; }
如果使用 Eager Loading,像下边这样,则一次性执行一次SQL查询。
Eager Loading
$articles = App\Article::with('author')->get(); foreach ($articles as $article) { echo $article->author->name; }
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
短答案:你需要使用Eager Loading
长答案:
像下边这样的查询和遍历,如果返回10条
article数据,则一共会执行11次SQL语句,第一条是一次性查询所有10条article数据,另外每次遍历都会执行一次获取相应author数据的SQL查询(原因是Eloquent默认为Lazy Loading,访问关系数据的时候才进行查询操作)。如果使用
Eager Loading,像下边这样,则一次性执行一次SQL查询。