Как реализовать вложенный запрос MySQL в Laravel Eloquent с использованием Laravel 5.6 - PullRequest
0 голосов
/ 05 марта 2019

Это мой запрос 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()

Что я делаю не так?

Ответы [ 2 ]

0 голосов
/ 05 марта 2019

Поскольку никто не мог ответить мне до того, как я получу свой собственный ответ, я пишу здесь код для людей, которые могут наткнуться на ту же проблему.

Основная проблема заключалась в том, что я использовал функцию 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();
0 голосов
/ 05 марта 2019

Вы можете попробовать

$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();

Как это сделать в Laravel, подзапрос, где в

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...