اذهب إلى المحتوى

السؤال

نشر

لقد قمت باستخدام with مع الاستعلامات في بعض الاستعلامات ضمن مشروعي:

$books = Book::with('author:id,name')->get();

ولكن في التوثيق الرسمي لاحظت وجود تابع آخر له نتيجة مشابهة:

use App\Models\Book;

$books = Book::all();

if ($someCondition) {
    $books->load('author', 'publisher');
}

فما الفرق بين with و load. ومتى يتم استخدام كل منها؟

Recommended Posts

  • 0
نشر

العمليتين load و with متشابهتين وستحصل على نفس النتيجة فلا يوجد فارق بالنتيجة النهائية لكل منها. ولكن الفرق الوحيد هو بترتيب التنفيذ عند استخدامها:

فعند استخدام with يتم أولاً تحميل المودل المرتبط عند تهيئة الاستعلام المراد تنفيذه (مثل: all أو first أو find...)

$users = User::with('comments')->get(); 

كأننا نقوم بتنفيذ:

select * from `users`
select * from `comments` where `comments`.`user_id` in (1, 2, 3, 4, 5)

أما عند استخدام load يتم أولاً تهيئة الاستعلام والحصول على السجلات، ثم يتم بعدها تحميل سجلات المودل المرتبطة بها.

بحيث يتم تقسيمها إلى مرحلتين:

$users = User::all();

كأننا نقوم باستعلام عادي

select * from `users`

ثم يتم تنفيذ:

$users = $users->load('comments');

والتي تقوم بدورها بتنفيذ استعلام آخر منفصل

select * from `comments` where `comments`.`user_id` in (1, 2, 3, 4, 5)

 

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...