Home > Database > Mysql Tutorial > Laravel Eloquent ORM in Bangla Part-Pruning Models)

Laravel Eloquent ORM in Bangla Part-Pruning Models)

Mary-Kate Olsen
Release: 2025-01-16 20:18:11
Original
942 people have browsed it

Laravel Eloquent ORM in Bangla Part-Pruning Models)

Laravel Eloquent’s model pruning feature allows you to automatically delete outdated or unwanted records in your database. This helps improve performance of large databases and prevents unnecessary data accumulation. In Laravel, you can perform pruning operations through scheduled tasks or Artisan commands.

Main method:

1. Old model pruning (delete old records)

This method can be used when old records need to be deleted after a specific time. For example, if you want a post to be automatically deleted 30 days after it was created, you can use the trim feature.

Use prune() method:

Laravel Eloquent 8.x version introduced the prune() method. This method is designed to delete records based on specific conditions.

<code class="language-php">use App\Models\Post;

class Post extends Model
{
    protected static function booted()
    {
        static::pruning(function ($query) {
            // 删除 30 天前创建的帖子
            $query->where('created_at', '<', now()->subDays(30));
        });
    }
}</code>
Copy after login

Every time you run Post::prune() it will delete posts that are 30 days old.

2. Use scheduled tasks for pruning

You can use Laravel's task scheduling function to regularly delete old data at a specific time.

Create a scheduled task:

  1. Open the app/Console/Kernel.php file and add your pruning task in the schedule() method.
<code class="language-php">use App\Models\Post;
use Illuminate\Console\Scheduling\Schedule;
use Illuminate\Foundation\Console\Kernel as ConsoleKernel;

class Kernel extends ConsoleKernel
{
    protected function schedule(Schedule $schedule)
    {
        // 每天凌晨 1 点修剪旧帖子
        $schedule->call(function () {
            Post::where('created_at', '<', now()->subDays(30))->delete();
        })->dailyAt('01:00');
    }
}</code>
Copy after login

This will delete posts from 30 days ago every day at 1am.

3. Use Artisan commands to trim

You can also perform trimming operations manually using Artisan commands. Delete data by creating a new Laravel Artisan command.

Create custom Artisan commands:

  1. Create command:
<code class="language-bash">php artisan make:command PruneOldPosts</code>
Copy after login
  1. Create a custom command in the app/Console/Commands/PruneOldPosts.php file:
<code class="language-php">namespace App\Console\Commands;

use Illuminate\Console\Command;
use App\Models\Post;

class PruneOldPosts extends Command
{
    protected $signature = 'posts:prune-old';
    protected $description = 'Prune posts older than 30 days';

    public function handle()
    {
        // 删除 30 天前创建的帖子
        Post::where('created_at', '<', now()->subDays(30))->delete();

        $this->info('Old posts pruned successfully!');
    }
}</code>
Copy after login
  1. Run command:
<code class="language-bash">php artisan posts:prune-old</code>
Copy after login

This will run manually and delete posts that are 30 days old.

4. Soft delete and trim

Sometimes you may want to use soft delete, which means not completely deleting the record, but just marking it as "deleted". In this case, you can combine soft delete and trim functions.

<code class="language-php">use App\Models\Post;

class Post extends Model
{
    use SoftDeletes;

    protected static function booted()
    {
        static::pruning(function ($query) {
            // 修剪 30 天前软删除的帖子
            $query->where('deleted_at', '<', now()->subDays(30));
        });
    }
}</code>
Copy after login

This will delete soft-deleted posts that are 30 days old.

5. Pruning and Eloquent relationship

When you want to delete records that are related to records, you need to delete those relationships at the same time. For example, if you want when a post is deleted to also delete its associated comments, you can use cascading delete.

<code class="language-php">class Post extends Model
{
    use SoftDeletes;

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

    protected static function booted()
    {
        static::deleting(function ($post) {
            // 删除帖子时删除所有评论
            $post->comments()->delete();
        });
    }
}</code>
Copy after login

This will ensure that when a post is deleted its associated comments are also deleted.

The above is the detailed content of Laravel Eloquent ORM in Bangla Part-Pruning Models). For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template