DEV Community

Cover image for Laravel Eloquent ORM in Bangla Part-5 (Inserting and Updating Models)
Sontus Chandra Anik
Sontus Chandra Anik

Posted on

Laravel Eloquent ORM in Bangla Part-5 (Inserting and Updating Models)

Laravel Eloquent-এ Inserting and Updating Models ডাটাবেস টেবিলে নতুন ডেটা যোগ করা এবং বিদ্যমান ডেটা আপডেট করার জন্য ব্যবহৃত হয়। এটি অত্যন্ত সহজ এবং ইনটুইটিভ পদ্ধতিতে কাজ করে। নিচে বিস্তারিতভাবে এই বিষয়গুলো আলোচনা করা হলো।

Inserting Models (ডেটা যোগ করা)

১. নতুন রেকর্ড তৈরি (Using save Method)

Eloquent মডেল তৈরি এবং সেভ করতে save() মেথড ব্যবহার করা হয়।

use App\Models\Post;

// নতুন পোস্ট তৈরি
$post = new Post();
$post->title = 'New Blog Post';
$post->content = 'This is the content of the post.';
$post->status = 'draft';

// ডেটা সেভ করুন
$post->save();

Enter fullscreen mode Exit fullscreen mode
  • উপরের উদাহরণে ডেটা মডেলে অ্যাসাইন করার পরে save() মেথড কল করা হয়।
  • এটি ডাটাবেসে নতুন রেকর্ড তৈরি করে।

২. সংক্ষিপ্ত পদ্ধতি (Using create Method)

create() মেথড সরাসরি এক লাইনে ডেটা ইনসার্ট করে।

use App\Models\Post;

Post::create([
    'title' => 'Quick Blog Post',
    'content' => 'This is the content.',
    'status' => 'published',
]);

Enter fullscreen mode Exit fullscreen mode

Note: create() ব্যবহারের জন্য আপনার মডেলে fillable বা guarded প্রপার্টি ডিফাইন করতে হবে।

class Post extends Model
{
    protected $fillable = ['title', 'content', 'status'];
}

Enter fullscreen mode Exit fullscreen mode

৩. ডাটাবেসে একাধিক রেকর্ড যোগ করা (Mass Insert)

insert() মেথড ব্যবহার করে একসঙ্গে একাধিক রেকর্ড ইনসার্ট করা যায়।

use App\Models\Post;

Post::insert([
    ['title' => 'Post 1', 'content' => 'Content 1', 'status' => 'published'],
    ['title' => 'Post 2', 'content' => 'Content 2', 'status' => 'draft'],
]);

Enter fullscreen mode Exit fullscreen mode

Updating Models (ডেটা আপডেট করা)

. নির্দিষ্ট রেকর্ড আপডেট করা (Using save Method)

ডাটাবেস থেকে একটি মডেল ফেচ করে এর ডেটা আপডেট করা যায়।

use App\Models\Post;

// রেকর্ড খুঁজে বের করুন
$post = Post::find(1);

// ডেটা আপডেট করুন
$post->title = 'Updated Blog Post';
$post->status = 'published';

// সেভ করুন
$post->save();

Enter fullscreen mode Exit fullscreen mode

২. update() মেথড ব্যবহার করে আপডেট করা

update() মেথড সরাসরি একাধিক কলাম আপডেট করতে ব্যবহৃত হয়।

use App\Models\Post;

Post::where('id', 1)->update([
    'title' => 'Updated Title',
    'status' => 'published',
]);

Enter fullscreen mode Exit fullscreen mode

৩. অনেক রেকর্ড একসঙ্গে আপডেট করা

update() ব্যবহার করে একাধিক রেকর্ড আপডেট করা যায়।

use App\Models\Post;

Post::where('status', 'draft')->update(['status' => 'archived']);

Enter fullscreen mode Exit fullscreen mode

Inserting or Updating Without Retrieving (Upsert)

upsert() মেথড নতুন ডেটা যোগ করা বা বিদ্যমান ডেটা আপডেট করার জন্য ব্যবহৃত হয়।

use App\Models\Post;

Post::upsert([
    ['id' => 1, 'title' => 'Upserted Title 1', 'status' => 'published'],
    ['id' => 2, 'title' => 'Upserted Title 2', 'status' => 'draft'],
], ['id'], ['title', 'status']);

Enter fullscreen mode Exit fullscreen mode

Explanation:

  1. প্রথম প্যারামিটার: ইনসার্ট বা আপডেট করার জন্য ডেটা।
  2. দ্বিতীয় প্যারামিটার: কী দ্বারা বিদ্যমান রেকর্ড সনাক্ত করা হবে।
  3. তৃতীয় প্যারামিটার: কোন কলামগুলো আপডেট হবে।

Timestamps and Soft Deletes Handling

১. timestamps অটোমেটিক আপডেট

Laravel ডিফল্টভাবে created_at এবং updated_at কলামগুলো আপডেট করে।

$post = Post::find(1);
$post->status = 'archived';
$post->save(); // `updated_at` কলাম অটোমেটিক আপডেট হবে

Enter fullscreen mode Exit fullscreen mode

২. Soft Delete Handling

যদি আপনার মডেলে Soft Deletes সক্রিয় থাকে, তাহলে ডেটা মুছে ফেলার পরিবর্তে deleted_at কলাম আপডেট হবে।

$post->delete(); // Soft Delete

Enter fullscreen mode Exit fullscreen mode

Bulk Insert and Update Best Practices

  • Single Transaction: একাধিক অপারেশন করার সময় ডেটাবেস ট্রানজেকশন ব্যবহার করুন।
DB::transaction(function () {
    Post::create([...]);
    Post::update([...]);
});

Enter fullscreen mode Exit fullscreen mode
  • Validate Data: ইনসার্ট বা আপডেট করার আগে ডেটা যাচাই করুন।
  • Use Mass Assignment Protection: $fillable বা $guarded সঠিকভাবে ব্যবহার করুন।

Billboard image

The Next Generation Developer Platform

Coherence is the first Platform-as-a-Service you can control. Unlike "black-box" platforms that are opinionated about the infra you can deploy, Coherence is powered by CNC, the open-source IaC framework, which offers limitless customization.

Learn more

Top comments (0)

Sentry image

See why 4M developers consider Sentry, “not bad.”

Fixing code doesn’t have to be the worst part of your day. Learn how Sentry can help.

Learn more