首页 >后端开发 >php教程 >如何使用 Laravel Eloquent 的 `with()` 函数有选择地从连接表中检索列?

如何使用 Laravel Eloquent 的 `with()` 函数有选择地从连接表中检索列?

Patricia Arquette
Patricia Arquette原创
2024-12-20 05:03:17191浏览

How Can I Selectively Retrieve Columns from Joined Tables Using Laravel Eloquent's `with()` Function?

Laravel Eloquent 中使用“With()”函数进行选择性列检索

使用 Eloquent 模型时的一个常见要求是需要加入多个表并从连接的表中检索特定列。虽然“with()”函数提供了一种指定关系的便捷方法,但它最初会从相关表中获取所有列。

在提供的示例中,目标是从“users”表,同时使用“with()”将其与“posts”表连接起来。初始实现从两个表中获取所有列,从而产生以下查询:

select * from `posts`
select * from `users` where `users`.`id` in (<1>, <2>)

要从连接表中仅检索所需的列,可以将闭包函数作为第二个参数传递给“with( )" 如下:

Post::query()
    ->with(['user' => function ($query) {
        $query->select('id', 'username');
    }])
    ->get()

此修改将执行以下查询:

select * from `posts`
select id, username from `users` where `users`.`id` in (<1>, <2>)

此方法确保仅指定使用“with()”函数进行关系连接时,从连接表中检索列。

重要提示:

包含主键(id)至关重要在本例中)作为闭包函数中 $query->select() 的第一个参数。这是正确检索连接表中结果所必需的。

以上是如何使用 Laravel Eloquent 的 `with()` 函数有选择地从连接表中检索列?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn