dqlm80253 2018-07-26 23:14
浏览 45
已采纳

Laravel 5中的子关系?

Currently I've got 3 models, Listing, Offer & Payment which have the following relationships:

Listing

class Listing extends Model {

    public function offers() {
        return $this->hasMany(\App\Models\Offer::class)->orderBy('created_at', 'desc');
    }

}

Offer

class Offer extends Model {

    public function payment() {
        return $this->hasOne(\App\Models\Payment::class, 'item_id', 'id')->where('item_type', \App\Models\Offer::class)->where('status', '1');
    }

    public function listing() {
        return $this->belongsTo(\App\Models\Listing::class)->withTrashed();
    }

}

Payment

class Payment extends Model {

    public function offer() {
        return $this->belongsTo(\App\Models\Offer::class, 'item_id', 'id')->withTrashed();
    }

}

How can I go from them Listing model & return a relationship with the payments table directly?

Listing can have unlimited amounts of Offer but Offer can only have 1 max Payment

To find any corresponding payment information, I'm having to query the Offer based on the listing_id within the model, and then access the Offer->payment, when I'd much prefer to be able to just do something like this:

$transaction_id = $id;

$listing = Listing::whereHas('payment', function($q) use ($id) {
        $q->where('transaction_id', $id);
        $q->where('user_id', Auth::user()->id);
})->first();
  • 写回答

1条回答 默认 最新

  • dongxueji2838 2018-07-26 23:39
    关注

    Use HasManyThrough:

    public function payments() {
        return $this->hasManyThrough(Payment::class, Offer::class, null, 'item_id')
            ->where('payments.item_type', Offer::class)
            ->where('payments.status', '1')
            ->orderBy('offers.created_at', 'desc');
    }    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c