ホームページ > データベース > mysql チュートリアル > Laravel の多対多リレーションシップで追加のピボット列の値にアクセスするにはどうすればよいですか?

Laravel の多対多リレーションシップで追加のピボット列の値にアクセスするにはどうすればよいですか?

Barbara Streisand
リリース: 2024-11-10 02:19:02
オリジナル
287 人が閲覧しました

How Can I Access the Value of an Extra Pivot Column in Laravel Many-to-Many Relationships?

Laravel で追加のピボット列の値を取得する

Laravel で多対多の関係を扱う場合、Eloquent は次の便利な方法を提供します。自動割り当てされたピボット属性を介してピボット テーブルの列にアクセスします。この例では、特定のモデルと問題の価格値を簡単に取得する方法を示します。

関係の定義

class PhoneModel extends \Eloquent
{
    public function problems()
    {
        return $this->belongsToMany('RL\Phones\Entities\PhoneProblem')->withPivot('price');
    }
}

class PhoneProblem extends \Eloquent
{
    public function models()
    {
        return $this->belongsToMany('PhoneModel')->withPivot('price');
    }
}
ログイン後にコピー

withPivot('price')句は、関係に含める追加のピボット列を指定します。

価格のクエリ

特定のモデルと問題の価格を取得するには、次の構文を使用します。

$model->problems()->where('phone_problem', $problem->id)->first()->pivot->price
ログイン後にコピー

この行は次のタスクを実行します。

  • $model に関連付けられている問題を取得します。
  • 指定された $problem-> によって問題をフィルターします。 ;id.
  • 最初に一致した問題を返します。
  • 価格値を取得するためにピボット属性にアクセスします。

このアプローチは、簡潔で Laravel に優しい方法を提供します。複雑なデータベース クエリを必要とせずに、追加のピボット列の値を取得します。

以上がLaravel の多対多リレーションシップで追加のピボット列の値にアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート