Mahmoud Alrashidi نشر 1 مارس 2021 أرسل تقرير نشر 1 مارس 2021 لدي مشروع لارافيل يحتوي على نظام تعليقات كل مقال لديه مجموعة من التعليقات: public function comments() { return $this->hasMany(Comment::class); } و لكل تعليق عدد من الردود: @foreach($article->comments as $comment) {{ $comment->body }} @foreach($comment->children as $subComment) {{ $subComment->body }} @endforeach @endforeach لكن لاحظت أن عدد الإستعلامات كبير، لماذا و كيف يُمكن التقليل من عدد الإستعلامات هذا. اقتباس
1 سمير عبود نشر 1 مارس 2021 أرسل تقرير نشر 1 مارس 2021 للتخلص من الإستعلامات الإضافية او تخفيض عدد الإستعلامات إستخدم دائماً التحميل الحثيث Eager loading او التحميل المُسبق للعلاقات لأنه عند إستخدامك للعلاقة كخاصية من دون التحميل الحثيث سيتم إجراء إستعلام إضافي في كل مرة و هذه المُشكلة تُسمى ب N + 1 أي من أجل كل كائن تستعلم N مرة إضافية. ففي حالتك مثلاً: في النموذج Comment public function children() { return $this->hasMany(Comment::class, 'parent_id'); } في المُتحكم: public function show($slug) { $article = Article::with(['comments' => function ($query) { $query->with('children')->where('status', true); }])->where('slug', $slug)->firstOrFail(); return view('article.show', compact('article')); } في صفحة العرض تكون بهذا الشكل مثلاً: @foreach($article->comments as $comment) {{ $comment->body }} @foreach($comment->children as $subComment) {{ $subComment->body }} @endforeach @endforeach 1 اقتباس
السؤال
Mahmoud Alrashidi
لدي مشروع لارافيل يحتوي على نظام تعليقات كل مقال لديه مجموعة من التعليقات:
و لكل تعليق عدد من الردود:
@foreach($article->comments as $comment) {{ $comment->body }} @foreach($comment->children as $subComment) {{ $subComment->body }} @endforeach @endforeach
لكن لاحظت أن عدد الإستعلامات كبير، لماذا و كيف يُمكن التقليل من عدد الإستعلامات هذا.
1 جواب على هذا السؤال
Recommended Posts
انضم إلى النقاش
يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.