Laravel: Eager Loading ও N+1 Query Problem সমাধান বাংলায় | Part 9.4

Abu Sayed
3 min readFeb 20, 2024

--

Laravel-এ Eager Loading কি এবং কেন ব্যবহার করা হয় সে সম্পর্কে বাংলায় জানুন। সাথে N+1 Query Problem কী এবং কিভাবে এটি সমাধান করতে হয় জানুন।

ভাই, তোমাকে Laravel-এর eager loading এবং N+1 query problem সম্পর্কে বাংলায় শিখিয়ে দেওয়ার চেষ্টা করবো। এই বিষয়টি খুবই গুরুত্বপূর্ণ, তাই সবকিছু সহজে বোঝার চেষ্টা করবো।

Eager Loading কী?

প্রথমে জানা দরকার যে Eager loading হলো Laravel-এর একটি ফিচার যা দিয়ে আমরা একই সাথে মডেলের সব রিলেশনশিপ ডাটা লোড করতে পারি।

উদাহরণস্বরূপ, আমাদের একটি Post মডেল আছে যার একটি Author মডেলের সাথে একটি belongsTo রিলেশনশিপ আছে। সাধারণভাবে আমরা Post মডেলটি কোয়েরি করলে শুধু Post ডাটাই পাবো, Author ডাটা পাবার জন্য আবার আলাদা কোয়েরি করতে হবে।

কিন্তু Eager Loading ব্যবহার করলে প্রথম কোয়েরিতেই Author ডাটা লোড হয়ে যাবে। এটা দিয়ে ডাটাবেস কল এবং পারফর্মেন্স অনেক উন্নত হয়।

Eager Loading করার উদাহরণ

// Eager load the Author relationship
$posts = Post::with('author')->get();
foreach ($posts as $post) {
echo $post->author->name;
}

এখানে with() মেথডটি Author relationship কে ইতিমধ্যেই লোড করে নিচ্ছে। তাই প্রতিটি পোস্টের জন্য আলাদা কোয়েরি করা লাগছে না।

একাধিক রিলেশনশিপও একইসাথে লোড করা যায়:

$posts = Post::with('author', 'comments')->get();

এভাবে Eager Loading দিয়ে N+1 প্রবলেম এড়ানো যায়।

N+1 Problem কী?

N+1 Problem হলো যেখানে প্রতিটি মডেল ডাটার জন্য আলাদা করে কোয়েরি করা হয়।

উদাহরণস্বরূপ ধরুন আমাদের আছে 100টি পোস্ট। প্রতিটি পোস্টের জন্য আমরা অথর ডাটা লোড করতে চাই। তাহলে প্রতিটি পোস্টের জন্য আমাদের 101টি কোয়েরি করতে হবে।

// ১ম কোয়েরি সব পোস্ট ডাটা নিতে
$posts = Post::all(); // ১ম কোয়েরি
// প্রতিটি পোস্টের জন্য অথর ডাটা নেওয়ার জন্য আরও ১০০টি কোয়েরি
foreach ($posts as $post) {
$author = $post->author; // প্রতিটি পোস্টের জন্য ১০০টি কোয়েরি
}
// মোট ১০১ কোয়েরি (১ম কোয়েরি + ১০০টি পোস্টের জন্য ১০০টি কোয়েরি)

এটা খুবই ক্ষতিকর কারণ প্রতিটি কোয়েরিতে ডাটাবেস কানেকশন ওপেন করা হয় এবং বন্ধ করা হয়। ফলে পারফর্মেন্স খারাপ হয়ে যায়।

Eager Loading দিয়ে N+1 সমস্যা সমাধান

Eager Loading ব্যবহার করে একবারেই সব রিলেটেড ডাটা লোড করে নেওয়া যায়। তাহলে শুধু ১টি কোয়েরিতেই সব ডাটা পাওয়া যায়।

// Eager load the Author relationship
$posts = Post::with('author')->get();
// Now we can loop without extra queries
foreach ($posts as $post) {
echo $post->author->name;
}
// Only 1 query instead of 101!

এভাবে Eager Loading দিয়ে N+1 প্রবলেম সমাধান করা যায় এবং পারফর্মেন্স উন্নত করা যায়।

সাবধানে ব্যবহার করা উচিত

যদিও Eager Loading খুবই উপকারী, তবুও সব সময়ই এটি ব্যবহার করা উচিত নয়। কারণ এটি অপ্রয়োজনীয় ডাটা লোড করে ফেলতে পারে যা পারফর্মেন্সের ক্ষতি করবে।

তাই শুধুমাত্র প্রয়োজনেই Eager Loading ব্যবহার করা উচিত।

সারাংশ

  • Eager Loading দিয়ে রিলেশনশিপ ডাটা একসাথে লোড করা যায়।
  • এটি N+1 প্রবলেম এড়ানোর জন্য খুবই গুরুত্বপূর্ণ।
  • তবে সব সময় এটি ব্যবহার করা ঠিক নয়, শুধুমাত্র প্রয়োজনেই ব্যবহার করা উচিত।

আশা করি তোমার জন্য Laravel-এর এই গুরুত্বপূর্ণ বিষয়টি বোঝানোর চেষ্টায় আমি সফল হয়েছি। যদি আরও কোন জিজ্ঞাসা থাকে তাহলে জানাতে ভুলিও না। আমি তোমাকে শিখিয়ে দেওয়ার চেষ্টা করবো।

--

--

Abu Sayed

Bangladeshi Full Stack Web Dev, Sys Admin & DevOps Engineer. Skills: Data analysis, SQL, Kubernetes. Python, PHP & Laravel. Me on: bd.linkedin.com/in/imabusayed