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

ما الفرق بين load و with في لارافيل؟

Amir Alsaeed

السؤال

لقد قمت باستخدام 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.

  • إعلانات

  • تابعنا على



×
×
  • أضف...