如何使用 Laravel 5.6 在 Laravel Eloquent 中实现嵌套 MySQL 查询
Posted
技术标签:
【中文标题】如何使用 Laravel 5.6 在 Laravel Eloquent 中实现嵌套 MySQL 查询【英文标题】:How to implement nested MySQL query in Laravel Eloquent using Laravel 5.6 【发布时间】:2019-07-26 14:43:34 【问题描述】:这是我的 mysql 查询:
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')
我试着像这样写 Laravel 雄辩的代码:
$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();
我收到此错误:
Call to undefined method Illuminate\Database\Query\Builder::table()
我做错了什么?
【问题讨论】:
How to do this in Laravel, subquery where in的可能重复 【参考方案1】:你可以试试
$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();
How to do this in Laravel, subquery where in
【讨论】:
【参考方案2】:由于在我得到自己的答案之前没有人可以回答我,因此我将代码放在这里,以供可能遇到同样问题的人使用。
主要问题是,我在子查询中使用了 table() 函数。更好的解决方案是使用 from() 函数。
代码 sn-p 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();
【讨论】:
以上是关于如何使用 Laravel 5.6 在 Laravel Eloquent 中实现嵌套 MySQL 查询的主要内容,如果未能解决你的问题,请参考以下文章
如何使用 Laravel 5.6 在 Laravel Eloquent 中实现嵌套 MySQL 查询
如何在 laravel 5.6 的一个刀片文件中使用不同的形式
Larave使用composer安装无反应,提示“Changed current directory to C:/Users/Administrator/AppData/Roaming/Compose