0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【Laravel】中間テーブルの定義でPivotを使った場合のBefore/After

Posted at

環境

Laravel v9.5.1 (PHP v8.1.3)

usersテーブル
id - integer
name - string

rolesテーブル
id - integer
name - string

role_userテーブル
user_id - integer
role_id - integer

Pivotを使わない場合

Models/RoleUser.php
class RoleUser extends Model
{
  ...
  public function user(): BelongsTo
  {
	return $this->belongsTo(User::class);
  }

  public function role(): BelongsTo
  {
	return $this->belongsTo(Role::class);
  }
}
Models/User.php
class User extends Model
{
  ...
  public function roleUsers(): HasMany
  {
	return $this->hasMany(RoleUser::class);
  }
}
Models/Role.php
class Role extends Model
{
  ...
  public function roleUsers(): HasMany
  {
	return $this->hasMany(RoleUser::class);
  }
}

userからroleを取得するとき、めちゃくちゃめんどくさいし分かりづらい!

User::first()->roleUsers()->first()->role()->first()

Pivotを使う場合

Models/RoleUser.php
use Illuminate\Database\Eloquent\Relations\Pivot;

class RoleUser extends Pivot
{
  ...
  public function user(): BelongsTo
  {
	return $this->belongsTo(User::class);
  }

  public function role(): BelongsTo
  {
	return $this->belongsTo(Role::class);
  }
}
Models/User.php
class User extends Model
{
  ...
  public function roles(): BelongsToMany
  {
	return $this->belongsToMany(Role::class, 'role_user', 'user_id', 'role_id');
  }
}
Models/Role.php
class Role extends Model
{
  ...
  public function users(): BelongsToMany
  {
	return $this->belongsToMany(User::class, 'role_user', 'user_id', 'role_id');
  }
}

userからroleを取得するとき下記のようにしたら取得できるので、シンプルで分かりやすい!

User::first()->roles()

参考

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?