如何从 laravel 的 eloquent 集合中获取外键

Posted

技术标签:

【中文标题】如何从 laravel 的 eloquent 集合中获取外键【英文标题】:How to get foreign key from eloquent collection in laravel 【发布时间】:2021-09-08 14:08:49 【问题描述】:

我的用户模型中有 hasMany 关系;

 /**
 * Get the posts for the users.
 */
public function posts()

    return $this->hasMany(Posts::class); //foreign key assigned by user_id

我需要在 Eloquent 数据中获取一个外来 id

控制器;

use App\Models\User;

$posts = User::find(1)->posts;

foreach ($posts as $post) 
    //

//for example
$foreign_key = $posts->foreign_key;
echo "all posts collection assigned foreign key is; ".$foreign_key;

预期输出;

1

如何获取外键?

【问题讨论】:

【参考方案1】:

您可以执行以下操作。由于帖子具有hasmany 关系,因此即使您在帖子中有一项,它也会返回对象集合。

foreach ($posts as $post) 
     
    echo $post->user_id;

 dd($posts->first()->user_id);

如果您仍然需要帖子关系中的一项,则可以添加一项关系

public function post()

    return $this->hasOne(Posts::class); //foreign key assigned by user_id

然后你就可以访问了

$posts = User::find(1)->post;

$foreign_key =$posts->user_id;

【讨论】:

我没有使用每个,你的第二个建议dd($posts->first()->user_id); 很好,但我得到了“尝试获取非对象的属性'user_id'”错误。有时表没有任何记录。 尝试添加条件 if($post=$posts->first()) dd($post->user_id); ) 是的,您只能在其有关系或不能直接做的情况下做。

以上是关于如何从 laravel 的 eloquent 集合中获取外键的主要内容,如果未能解决你的问题,请参考以下文章

Laravel Eloquent API 资源:从响应(集合)中删除“数据”键

如何通过索引将项目添加到 Laravel Eloquent 集合中?

Laravel Eloquent - 如何将范围查询内的计算值作为模型列或集合属性返回

如何从 Laravel 的集合中计算不同的值?

遍历数组集合并返回命名键值对(Laravel/Eloquent)

laravel eloquent 'has' 方法的行为出人意料