dongsu3138 2015-07-13 16:19
浏览 64
已采纳

laravel hasManyThrough属于belongsTo关系

I have the following Eloquent relationships where

Farm -> hasOne -> Address as follows :

/**
 * \App\Address associated to the current farm.
 *
 * @return \App\Address
 */
public function address()
{
    return $this->hasOne('\App\Address');
} 

...then Address -> belongsTo -> Country as follows:

public function country()
{
    return $this->belongsTo('\App\Country','country_id','id');
}

... and I'm like to retrieve the Country model and get all associated farms using the country_id on the address table. I defined a hasManyThrough as follows:

/**
 * Get all of the farms for the country.
 */
public function farms()
{
    return $this->hasManyThrough('App\Farm', 'App\Address');
}

but it generates the following SQL:

select 
    `farms`.*, 
    `addresses`.`country_id` 
from `farms` 
inner join `addresses` on `addresses`.`id` = `farms`.`address_id` 
where `addresses`.`country_id` = 1

The SQL is looking for an address_id on the farms table. But the farm does not "belongTo" an address. Is there anyway to correct this or am I stuck needing a change to my schema?

Many thanks.

  • 写回答

1条回答 默认 最新

  • du970294 2015-07-13 17:17
    关注

    In order for that to work you'll need to reverse the direction of Farm-Address relation:

    class Farm extends Model {
      public function address() {
        return $this->belongsTo(Address::class);
      }
    }
    

    The reason is that Eloquent assumes that every "node" in hasManyThrough relation is kind of a parent for the next node, meaning the next node belongs to the previous node. Here if you want to get farms through address for given country, farm needs to point to address via address_id and address needs to point to country via country_id.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥65 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用