第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

3個(gè)表多對(duì)多關(guān)系

3個(gè)表多對(duì)多關(guān)系

PHP
明月笑刀無情 2021-11-05 13:21:10
我正在 Laravel 中創(chuàng)建一個(gè)網(wǎng)站并遇到以下問題。我有三個(gè)表:User、JobOffer和Company 許多用戶有很多工作機(jī)會(huì)。我在用戶和 Joboffers 之間創(chuàng)建了一個(gè)多對(duì)多的關(guān)系。用戶模型:return $this->belongsToMany('App\JobOffer')->withTimestamps();招聘模式:return $this->belongsToMany('App\User')->withTimestamps();但是問題是 Joboffers 表有一個(gè)列company_id(因?yàn)?Company 和 Joboffer 之間的關(guān)系)并且 Users-Joboffer 之間的關(guān)系返回了公司的 id。但是我想知道公司的名字。非常感謝!更新:我的模型:應(yīng)用\用戶.phppublic function job_offers(){    return $this->belongsToMany('App\JobOffer')->withTimestamps();}App\JobOffer.phppublic function users(){    return $this->belongsToMany('App\User')->withTimestamps();}public function company(){    return $this->belongsTo('App\Company');}應(yīng)用\公司.phppublic function job_offers(){    return $this->hasMany('App\JobOffer');}用戶IGP是對(duì)的。非常感謝IGP。
查看完整描述

1 回答

?
呼喚遠(yuǎn)方

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超11個(gè)贊

在提供更多細(xì)節(jié)之前,我假設(shè)關(guān)系如下:

  • 用戶模型和JobOffer模型具有 M:N 關(guān)系

  • 公司模型和JobOffer模型具有 1:M 關(guān)系

# App\User.php

public function job_offers()

{

    return $this->belongsToMany('App\JobOffer')->withTimestamps();

}

# App\JobOffer.php

public function users()

{

    return $this->belongsToMany('App\User')->withTimestamps();

}


public function company()

{

    return $this->belongsTo('App\Company');

}

# App\Company.php

public function job_offers()

{

    return $this->hasMany('App\JobOffer');

}

從這些關(guān)系中,您可以像這樣獲得公司名稱:


use App\User;


$user = User::with('job_offers.company')->where(...)->first();

生成的對(duì)象將如下所示:


App\User {

  id: 1,

  created_at: "",

  updated_at: "",

  job_offers: Illuminate\Database\Eloquent\Collection {

    all: [

      App\JobOffer {

        id: 85,

        company_id: 36,

        created_at: "",

        updated_at: "",

        pivot: Illuminate\Database\Eloquent\Relations\Pivot {

          job_offer_id: 85,

          user_id: 1,

          created_at: "",

          updated_at: "",

        },

        company: App\Company {

          id: 36,

          name: "Company1"

          created_at: "",

          updated_at: "",

        },

      },

      App\JobOffer {

        id: 90,

        company_id: 44,

        created_at: "",

        updated_at: "",

        pivot: Illuminate\Database\Eloquent\Relations\Pivot {

          job_offer_id: 90,

          user_id: 1,

          created_at: "",

          updated_at: "",

        },

        company: App\Company {

          id: 44,

          name: "Company2"

          created_at: "",

          updated_at: "",

        },

      },

    ],

  },

}

您需要做的就是遍歷用戶的工作機(jī)會(huì)以獲取每個(gè)公司名稱。


@foreach($user->job_offers as $job_offer)

    Company name: {{ $job_offer->company->name }}

@endforeach


查看完整回答
反對(duì) 回復(fù) 2021-11-05
  • 1 回答
  • 0 關(guān)注
  • 183 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)