定制 mdcoderu/sequential-code 二次开发

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

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

mdcoderu/sequential-code

最新稳定版本:v1.0.2

Composer 安装命令:

composer require mdcoderu/sequential-code

包简介

Laravel пакет для генерации последовательных 6-значных кодов для моделей

README 文档

README

Laravel пакет для генерации последовательных -значных кодов для моделей с поддержкой ручного указания кода.

Возможности

  • ✅ Автоматическая генерация уникальных 6-значных кодов
  • ✅ Возможность ручного указания кода
  • ✅ Потокобезопасность через транзакции и блокировки
  • ✅ Отдельная таблица счетчиков для каждой модели
  • ✅ Конфигурируемые границы кодов

Установка

1. Добавление пакета через Composer

composer require mdcoderu/sequential-code

2. Публикация миграции

php artisan vendor:publish --tag="sequential-code-migrations"

3. Запуск миграций

php artisan migrate

Использование

Базовое использование

Примените trait HasSequentialCode к вашей модели:

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use Mdcode\SequentialCode\Traits\HasSequentialCode;

use Mdcoderu\SequentialCode\Traits\HasSequentialCode;

class Order extends Model
{
    use HasSequentialCode;
    
    // ...
}

Теперь при создании новой записи код будет генерироваться автоматически:

$order = Order::create([
    // другие поля...
]);

echo $order->code; // "100000", "100001", ...

Ручное указание кода

Вы можете указать код вручную:

$order = Order::create([
    'code' => 123456,
    // другие поля...
]);

Кастомный ключ счетчика

По умолчанию в качестве ключа счетчика используется имя таблицы модели. Если нужно использовать кастомный ключ, переопределите метод getSequentialCodeKey():

class Order extends Model
{
    use HasSequentialCode;
  
    protected function getSequentialCodeKey(): string
    {
        return 'order_' . $this->type;
    }
}

Конфигурация

Пакет имеет конфигурационный файл config/sequential-code.php:

return [
    'min_code' => 100000, // Минимальное значение кода
    'max_code' => 999999, // Максимальное значение кода
];

Вы можете опубликовать конфигурацию:

php artisan vendor:publish --tag="sequential-code-config"

Таблица model_counters

Пакет использует таблицу model_counters для хранения текущих значений счетчиков:

Поле Тип Описание
key string (primary) Уникальный ключ счетчика
value unsigned integer Текущее значение счетчика

Ограничения

  • Код должен быть 6-значным числом (от 100000 до 999999)
  • При достижении максимума (999999) будет выброшено исключение RuntimeException
  • Для каждого ключа счетчика хранится отдельное значение

Лицензия

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固