如何使用 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 查询

larave学习笔记1-安装配置

如何在 laravel 5.6 的一个刀片文件中使用不同的形式

如何在 laravel 5.6 中下载 pdf 文件?

如何在 laravel 5.6 中创建自定义帮助文件?

Larave使用composer安装无反应,提示“Changed current directory to C:/Users/Administrator/AppData/Roaming/Compose