这是我的MySQL查询:
Elapsed Time = Connect Time + Latency + Server Response time
我试图这样编写Laravel雄辩的代码:
SELECT * FROM cc_calenders
WHERE
cc_calenders.user_id = 1
OR
cc_calenders.id = (
SELECT cc_calender_shares.calender_id
FROM cc_calender_shares
WHERE
cc_calender_shares.shared_with = 'epsita@matrixnmedia.com')
我收到此错误:
$records = Calender::where('user_id', $user_id)
->orWhere('id', function($query) use ($user_email) {
$query->table('calender_shares')
->select('calender_shares.calender_id')
->where('calender_shares.shared_with', $user_email);
})->get();
我在做什么错了?
答案 0 :(得分:2)
您可以尝试
$records = Calender::where('user_id', $user_id)
->orWhere('id', function($query) use ($user_email) {
$query->select('calender_id')
->from('calender_shares')
->where('shared_with', $user_email);
})->get();
答案 1 :(得分:2)
由于在我得到自己的答案之前没有人可以回答我,所以我将代码放到这里,供那些可能会遇到相同问题的人使用。
主要问题是,我正在子查询中使用table()函数。更好的解决方案是使用from()函数。
代码段from(with(new CalenderShare)->getTable())
为我提供了模型CalenderShare的表名。
Calender::where('user_id', $user_id)
->orWhereIn('id', function($query) use ($user_email) {
$query->from(with(new CalenderShare)->getTable())
->select('calender_shares.calender_id')
->where('calender_shares.shared_with', $user_email);
})->get();