簡體   English   中英

如何使用Laravel 5.6在Laravel Eloquent中實現嵌套MySQL查詢

[英]How to implement nested MySQL query in Laravel Eloquent using Laravel 5.6

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

我究竟做錯了什么?

你可以試試

$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中執行此操作,子查詢在哪里

由於沒有人能在得到自己的答案之前回答我,因此我將代碼放到這里,供那些可能會遇到相同問題的人使用。

主要問題是,我在子查詢中使用了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();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM