如何在laravel 5.2中获得与外键的一对多关系?

时间:2016-09-10 08:19:27

标签: php mysql laravel eloquent laravel-5.2

我正在使用laravel 5.2。我的数据库设置为:

social_logins
ID |   social_id  | provider
-----------------------------
 1 |      x      | twitter  
 2 |      y      | facebook
 3 |      z      | twitter

twitter_data
ID |   social_id  | some_value
-------------------------------
 1 |      x      | 100
 2 |      y      | 200
 3 |      z      | 100

我对social_logins模型的关系设置为:

 public function twitterData()
    {
        return $this->hasMany('App\Models\TwitterData', 'social_id');
    }

我想用表中的social_id外键检索所有的twitter数据。到目前为止,我已经尝试过:

$socialLogin = Social::find($id);
dd($socialLogin->twitterCounts);

但是当我尝试这个时,我只得到一个空集合

Collection {#346 ▼
  #items: []
}

如何在laravel 5.2中检索与外键的一对多关系?

当我手动执行此操作时请注意:

TwitterData::where('social_id', $socialLogin->social_id)->get();

它正确返回所有数据。

1 个答案:

答案 0 :(得分:1)

在关系方法中添加本地密钥:

public function twitterData()
    {
        return $this->hasMany('App\Models\TwitterData', 'social_id','social_id');
    }