定制 riftweb/superseeder 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

riftweb/superseeder

最新稳定版本:1.0.3

Composer 安装命令:

composer require riftweb/superseeder

包简介

Supercharge your Laravel database seeding with execution tracking and rollbacks! This package adds migration-like behavior to seeders, preventing duplicate runs while enabling batch management and safe rollback of seeded data. Perfect for production environments and complex seeding workflows.

README 文档

README

Latest Version Total Downloads License Website

A robust database seeder solution for Laravel with execution tracking and rollback capabilities. Brings migration-like behavior to your seeders! 🔄

Features ✨

  • ✅ Track executed seeders in seeder_executions table
  • ⏮️ Rollback seeders like migrations
  • 🛡️ Prevent accidental duplicate executions
  • 🔄 Batch management of seeders
  • 🚦 Bypass mode for emergency executions
  • 🚀 Generator command for trackable seeders

Installation 💻

Install via Composer:

composer require riftweb/superseeder

Run migrations (creates seeder_executions table):

php artisan migrate

Usage 🛠️

1. Create Trackable Seeder

php artisan make:superseeder UsersSeeder

2. Implement Seeder Logic

<?php

namespace Database\Seeders;

use Illuminate\Database\Seeder;
use Riftweb\SuperSeeder\Traits\TrackableSeed;

class UsersSeeder extends Seeder
{
    use TrackableSeed;

    public function up()
    {
        // Your seeder logic
    }

    public function down(): void
    {
        // Your rollback logic
    }
}

3. Run Seeders

php artisan superseed

4. Rollback Last Batch

php artisan superseed:rollback

Configuration ⚙️

Bypass Mode

Add to .env:

SUPERSEED_BYPASS=true

What it does:

  • When enabled, runs seeders regardless if they have been executed before (use with caution)
  • DOES create records in seeder_executions
  • Alternative: Use --force flag with superseed command

How It Works 🔍

  1. Tracking Table
    The package creates a seeder_executions table to track:

    • Seeder class name
    • Batch number
    • Execution timestamp
  2. Rollback Process

    • Calls down() method on each seeder
    • Deletes tracking records for the batch
    • Runs in reverse order of execution

Workflow Example 🔄

# 1. Create seeder
php artisan make:superseeder UsersSeeder

# 2. Implement up() and down() methods

# 3. Run seeders
php artisan superseed

# 4. Rollback
php artisan superseed:rollback

Commands 🛠️

Create trackable seeder
php artisan make:superseeder SeederName
Run seeders
php artisan superseed
Rollback seeders
php artisan superseed:rollback
Clear all seeder records
php artisan superseed:fresh
Clear all seeder records and rollback
php artisan superseed:clear

Important Notes ⚠️

  • Test rollbacks thoroughly before production use
  • Backup database before running seeders

Contributing 🤝

Contributions are welcome! Please follow:

  1. Fork the repository
  2. Create your feature branch
  3. Commit changes
  4. Push to the branch
  5. Open a PR

License 📄

MIT License - See LICENSE for details.

Crafted with ❤️ by RIFT | Web Development

统计信息

  • 总下载量: 38
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-03-28