如何使用Laravel 5.6在Laravel Eloquent中实现嵌套MySQL查询

时间:2019-03-05 07:36:40

标签: php mysql laravel laravel-5.6

这是我的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();

我在做什么错了?

2 个答案:

答案 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();

How to do this in Laravel, subquery where in

答案 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();