duansha6410 2015-07-02 17:30
浏览 38
已采纳

Laravel 5:如何使用Eloquent查询数据透视表

Is there a way to use Eloquent to query a pivot table without having a model for that pivot table?

Situation: a user can own multiple businesses, and a business can be owned by multiple users. I have the following tables to deal with the many-to-many relationship.

| users     | businesses  | business_user |
-------------------------------------------
| id        | id          | business_id   |
| name      | name        | user_id       |
| created_at| created_at  | created_at    |
| updated_at| updated_at  | updated_at    |

My User.php model

public function businesses()
{
    return $this->belongsToMany('App\Business')->withTimestamps();
}

My Business.php model

public function users()
{
    return $this->belongsToMany('App\User')->withTimestamps();
}

1- In my controller, i'm trying to query the business_user (pivot) table to count the number of businesses the Auth user Id has.

select count(*) from business_user where user_id = Auth::user()->id() ;

2- I'm trying to query the business_user (pivot) table to get the business name for each row found in table business_user for that user id.

select business_user.business_id, businesses.name 
  from business_user 
  join businesses 
    on business_user.business_id = businesses.id
 where business_user.user_id     = Auth::user()->id() ;

I would like to query the pivot table with Eloquent, but I can't get the syntax right. Do I need a model for that business_user table?

Do some of you prefer not using Eloquent at all?

Thanks cv

  • 写回答

1条回答 默认 最新

  • dqhbuwrwq692118284 2015-07-02 17:36
    关注

    You don't need Model for a Pivot table. Things you are asking for are pretty straight forward.

    Number of businesses the current logged in User has

    echo \Auth::user()->businesses->count();
    

    name of each business for current User

    foreach(\Auth::user()->businesses as $business){
      echo $business->name;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 反激PWM控制芯片调研
  • ¥15 Python for loop减少运行时间
  • ¥15 fluent模拟物质浓度udf
  • ¥15 Collection contains no element matching the predicate
  • ¥20 冻品电商平台的搜索是怎么实现的
  • ¥15 如何搞一个可以控制、显示马达频率
  • ¥15 WPF动态创建页面内容
  • ¥15 如何对TBSS的结果进行统计学的分析已完成置换检验,如何在最终的TBSS输出结果提取除具体值及如何做进一步相关性分析
  • ¥15 SQL数据库操作问题
  • ¥15 Matlab安装yalmip和cplex功能安装失败