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

السؤال

نشر

لدي مشروع لارافيل يحتوي على نظام تعليقات كل مقال لديه مجموعة من التعليقات:

public function comments()
{
  return $this->hasMany(Comment::class);
}

و لكل تعليق عدد من الردود:

@foreach($article->comments as $comment)
  {{ $comment->body }}

  @foreach($comment->children as $subComment)
  	{{ $subComment->body }}
  @endforeach
@endforeach

لكن لاحظت أن عدد الإستعلامات كبير، لماذا و كيف يُمكن التقليل من عدد الإستعلامات هذا.

Recommended Posts

  • 1
نشر

للتخلص من الإستعلامات الإضافية او تخفيض عدد الإستعلامات إستخدم دائماً التحميل الحثيث 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

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

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

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

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   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.

  • إعلانات

  • تابعنا على



×
×
  • أضف...