在 Laravel Eloquent 中通过 ID 保存一对多

Posted

技术标签:

【中文标题】在 Laravel Eloquent 中通过 ID 保存一对多【英文标题】:Saving one-to-many by IDs in Laravel Eloquent 【发布时间】:2021-12-31 11:02:34 【问题描述】:

我似乎忽略了基本的 Laravel Eloquent 功能。

使用以下(Mongo,使用Jenssegers package DB 结构和类:

Owner (id,car_ids)
Car (id)

Class Owner extends Model

  public function cars(): HasMany
  
    return $this->hasMany(Car::class);
  


Class Car extends Model

  public function owner(): BelongsTo
  
    return $this->belongsTo(Owner::class);
  

一个车主可以拥有多辆汽车,一辆汽车属于一个车主。

现在,我得到一个现有汽车 ID 列表作为输入,并希望将它们附加到现有车主。 我必须先循环并通过 id 找到汽车型号,然后使用 saveMany 吗?没有直接存储id的选项吗?

【问题讨论】:

【参考方案1】:

您应该在刀片上放置一个select 标签,如下所示:

<select name="cars[]" id="cars" multiple>
  <option value="1">Volvo</option>
  <option value="2">Saab</option>
  <option value="3">Opel</option>
  <option value="4">Audi</option>
</select>

然后,提交表单后,您可以获取汽车的 id 并使用saveMany,如下所示:

$owner = Owner::find(1);
$ids = $request->input('cars');
$owner->cars()->saveMany($ids);

【讨论】:

以上是关于在 Laravel Eloquent 中通过 ID 保存一对多的主要内容,如果未能解决你的问题,请参考以下文章

在 Laravel 中通过用户 ID 强制注销特定用户

在Laravel 5中通过ID和所有外国人递归获取记录

如何在laravel中通过id选择不同表上的关系数据

检查文件夹是不是已经存在,如果没有在 laravel 中通过 id 创建一个新文件夹

在 Laravel Auth() 中通过电子邮件/电话号码登录

如何在 Eloquent/Laravel 上查询子查询