繁体   English   中英

Yii2 viaTable多个变量

[英]Yii2 viaTable multiple variables

我试图找到一些UserComment使用viaTable在桌子上称为user_comment_userYii2 但是我似乎无法正确插入我的variables / query

目前我已经设置了两个queries ,以检查他们是否(他们自己)获得了正确的结果。

这些是以某种方式必须merged为一个的两个queries

public function findConversation($id)
{
    $query = $this->hasMany(UserComment::classname(), ['id'=>'user_comment_id'])
        ->viaTable('user_comment_user', ['sender_id'=>'id'], function ($query) use ($id) {
            $query->andWhere(['receiver_id'=>$id]);
        });
    $query2 = $this->hasMany(UserComment::classname(), ['id'=>'user_comment_id'])
        ->viaTable('user_comment_user', ['receiver_id'=>'id'], function ($query) use ($id) {
            $query->andWhere(['sender_id'=>$id]);
        });
        return $query;
}

答案实际上比我想象的要简单得多:

    public function findConversation($id)
    {
        $query = UserComment::find();
        $query->leftJoin('user_comment_user',      'user_comment_user.user_comment_id=user_comment.id');
        $query->where(['receiver_id'=>$this->id, 'sender_id'=>$id]);
        $query->orWhere(['receiver_id'=>$id, 'sender_id'=>$this->id]);
        $query->orderBy(['created_at'=>SORT_DESC]);

        return $query;
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

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