与laravel中的多对多关系分页

时间:2015-02-21 12:38:31

标签: mysql email laravel pagination eloquent

我试图在laravel 4.2中设置电子邮件系统。我有两个模型电子邮件和用户,他们之间有很多对多的关系。到目前为止一切都很好,但现在我只是在发送电子邮件时遇到问题。我已经尝试了2天,但还没有完成任务。

    //User.php    Model
    public function emails()
    {   
        return $this->belongsToMany('Email', 'users_email', 'reciever_uid','email_id')->
         withPivot('sender_UID');
    }

    //Email.php  Model
    public function users()
    {   
        return $this->belongsToMany('User', 'users_email', 'email_id','reciever_id');
    }

我已尝试获取users_email数据透视表数据以获取当前的所有电子邮件ID 经过身份验证的用户QueryBuilder。

    $user=Auth::Id();
    $user_data=DB::table('users_email')->
    join('users','users_email.reciever_uid','=','users.Id')->
    where('users_email.sender_uid','=',$user->Id)->orderby   
    ('users_email.email_id','desc')->get();

    foreach ($user_data as $data) {
    $id[]=$data->email_id;
   }

现在我有$ id数组,我想获取所有电子邮件以及要显示的接收器的f_name和l_name。 到目前为止,我已经尝试了一些基本知识的热切加载,但无法获得 预期结果。我已经尝试过这样的方法来对其中的所有电子邮件进行分页 $ id但是getTotal只返回2,即使下面显示的图片指定id = 78的电子邮件已经发送了8个以上,所以我想通过电子邮件进行分页。 E.x只准备了10封电子邮件。

    $pagination=User::with(array('emails'=>function($query) use ($id){
        $query->WhereIn('users_email.email_id',$id);
    }))->paginate(10);

非常感谢任何帮助。

谢谢

数据透视表users_email

enter image description here

1 个答案:

答案 0 :(得分:5)

你必须写两种不同的关系:

//User.php
public function emailsReceived()
{   
    return $this->belongsToMany('Email', 'users_email', 'reciever_uid','email_id')->withPivot('sender_uid');
}
public function emailsSent()
{   
    return $this->belongsToMany('Email', 'users_email', 'sender_uid','email_id')->withPivot('reciever_uid');
}

然后您将能够简单地检索发送的所有电子邮件:

$user = Auth::user();
$emailsSentByUser = $user->emailsSent;
$paginatedEmailsSentByUser = $user->emailsSent()->paginate(10);

请注意,当您在关系名称后面使用括号时,您可以链接查询构建器方法。