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

تقليل عدد الإستعلامات في لارافيل

Mahmoud Alrashidi

السؤال

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

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.

  • إعلانات

  • تابعنا على



×
×
  • أضف...