xianghuawe / laravel-archivable
This is laravel extension packages
Installs: 9
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/xianghuawe/laravel-archivable
Requires
- php: >=8.1
- laravel/framework: ^9.0|^10.0|^11.0
Requires (Dev)
- laravel/pint: ^1.0
- orchestra/testbench: ^7.0
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2025-10-20 09:26:21 UTC
README
Laravel Archivable 是一个用于数据库记录归档的 Laravel 扩展包,它能够将不需要的记录从主数据库移动到归档数据库,同时保持表结构同步。
功能特性
- 将模型记录归档到指定的归档数据库
- 自动同步主数据库和归档数据库之间的表结构
- 支持批量归档操作,可配置分块大小
- 提供命令行工具进行批量归档和表结构同步
- 支持自定义归档条件
安装
使用 Composer 安装包:
composer require xianghuawe/laravel-archivable
发布配置文件:
php artisan vendor:publish --provider="Xianghuawe\Archivable\ServiceProvider" --tag="config"
配置
在你的 .env 文件中配置归档数据库连接:
ARCHIVE_DB_CONNECTION=archive
确保在 config/database.php 中定义了 archive 数据库连接:
'connections' => [
    // 其他连接...
    
    'archive' => [
        'driver' => 'mysql',
        'host' => env('ARCHIVE_DB_HOST', '127.0.0.1'),
        'port' => env('ARCHIVE_DB_PORT', '3306'),
        'database' => env('ARCHIVE_DB_DATABASE', 'archive'),
        'username' => env('ARCHIVE_DB_USERNAME', 'root'),
        'password' => env('ARCHIVE_DB_PASSWORD', ''),
        'unix_socket' => env('ARCHIVE_DB_SOCKET', ''),
        'charset' => 'utf8mb4',
        'collation' => 'utf8mb4_unicode_ci',
        'prefix' => '',
        'strict' => true,
        'engine' => null,
    ],
],
使用方法
1. 在模型中使用 Archivable Trait
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Xianghuawe\Archivable\Archivable;
class User extends Model
{
    use Archivable;
    
    /**
     * 定义可归档的记录条件
     * 
     * @return \Illuminate\Database\Eloquent\Builder
     */
    public function archivable()
    {
        // 例如:归档超过一年未活跃的用户
        return $this->where('last_login_at', '<', now()->subYear());
    }
}
2. 同步表结构
在归档记录之前,确保归档数据库中存在对应的表结构:
php artisan model:archive-structure-sync
也可以指定特定的模型:
php artisan model:archive-structure-sync --model="App\Models\User" 
--model="App\Models\Order"
3. 归档记录
使用命令行归档记录:
php artisan model:archive
指定特定的模型:
php artisan model:archive --model="App\Models\User" --model="App\Models\Order"
设置分块大小:
php artisan model:archive --chunk=500
仅预览将归档的记录数量:
php artisan model:archive --pretend
4. 编程方式归档
// 归档单个记录
$user->archive();
// 归档符合条件的所有记录
$user->archiveAll($chunkSize = 1000);
事件
当模型记录被归档时,会触发 Xianghuawe\Archivable\ModelsArchived 事件,你可以监听这个事件来执行自定义逻辑:
use Illuminate\Support\Facades\Event;
use Xianghuawe\Archivable\ModelsArchived;
Event::listen(ModelsArchived::class, function ($event) {
    // $event->model 包含被归档的模型类名
    // $event->count 包含被归档的记录数量
    
    // 执行自定义逻辑
});
配置项
在 config/archive.php 中可以配置以下选项:
return [
    // 默认分块大小
    'default_chunk_size' => 1000,
    // 归档数据库连接
    'db' => env('ARCHIVE_DB_CONNECTION', 'archive'),
    // 模型扫描路径
    'model_paths' => [
        app_path('Models'),
    ],
];
要求
- PHP 8.1 或更高版本
- Laravel 9.0、10.0 或 11.0
许可证
该项目使用 MIT 许可证 - 详情请参阅 LICENSE 文件
贡献
欢迎贡献代码!请提交 Pull Request 或创建 Issue。
作者
- xianghuawe - xianghua_we@163.com
- GitHub: https://github.com/xianghuawe/laravel-archivable