我试图在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
答案 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);
请注意,当您在关系名称后面使用括号时,您可以链接查询构建器方法。