我试图在Laravel中根据文档使用预先加载来获取两个相关对象 .
https://laravel.com/docs/5.4/eloquent-relationships#eager-loading
我的模特是:
class Lead extends Model {
public function session() {
return $this->hasOne('App\LeadSession');
}
}
class LeadSession extends Model {
public function lead() {
return $this->belongsTo('App\Lead');
}
}
我想通过一个SQL查询获取两个对象 . 基本上我想执行:
select * from lead_sessions as s
inner join lead as l
on l.id = s.lead_id
where s.token = '$token';
然后能够访问LeadSession和Lead对象 . 这是我正在尝试的PHP代码:
$lead = Lead::with(['session' => function ($q) use ($token) {
$q->where('token','=',$token);
}])->firstOrFail();
print($lead->session->id);
我也尝试过:
$lead = Lead::whereHas('session', function($q) use ($token) {
$q->where('token','=',$token);
})->firstOrFail();
print($lead->session->id);
和
$session = LeadSession::with('lead')->where('token',$token)->firstOrFail();
print($session->lead->id);
在所有三种情况下,我都会执行两个查询,一个用于 leads
表,另一个用于 lead_sessions
表 .
在Eloquent中这样的事情是否可能?在我看来,它应该是一个标准的ORM操作,但由于某种原因,我正在努力一整天 .
我不想使用查询生成器,因为我想在之后使用Eloquent对象及其函数 .
我来自Python和Django,我想在Django中复制 select_related
函数的行为 .
1 回答
试试这个,看看它是否有多个查询
我希望它只运行一个查询 . 我没有测试过这个 . 不确定是否必须添加
select()
来选择列 . 但是,先试试这个 .Updates 只需添加如何使用会话和潜在客户数据 . 尝试选择并指定所需的数据 . 原因是如果两个表都有类似'id'的列,则其中一个将被覆盖 . 所以你必须为你的选择别名
现在所有这些数据都属于
$session
变量 . 对于您正在进行的测试