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

dev-main 2025-10-20 09:26 UTC

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。

作者