简体   繁体   中英

Eloquent where clause in JOIN table - Laravel 5.5

I have two models which are connected each other.

class Company extends Model {
   public function addresses() {
      return $this->belongsToMany('\App\Address', 'address_mapping', 'uid_company', 'uid_address');
   }
}

class Address extends Model {
}

In my JOIN table I have a column named active. How can I fetch all active addresses from the company? Or how can I implement a where-clause in the JOIN table?

Thank you!

The table that you call a "JOIN table", usually called a pivot table . You can fetch all active records by using wherePivot method:

 $company = Company::first();   
 $activeAdresses = $company->addresses()->wherePivot('active', 1);

Or you can directly define the relationship in your model:

class Company extends Model {
   public function activeAddresses() {
      return $this->belongsToMany('\App\Address', 'address_mapping', 'uid_company', 'uid_address')
                  ->wherePivot('active', 1);
   }
}

See section Filtering Relationships Via Intermediate Table Columns in Eloquent documentation

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM