Laravel пакет для генерации последовательных -значных кодов для моделей с поддержкой ручного указания кода.
- ✅ Автоматическая генерация уникальных 6-значных кодов
- ✅ Возможность ручного указания кода
- ✅ Потокобезопасность через транзакции и блокировки
- ✅ Отдельная таблица счетчиков для каждой модели
- ✅ Конфигурируемые границы кодов
composer require mdcoderu/sequential-codephp artisan vendor:publish --tag="sequential-code-migrations"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 для хранения текущих значений счетчиков:
| Поле | Тип | Описание |
|---|---|---|
| key | string (primary) | Уникальный ключ счетчика |
| value | unsigned integer | Текущее значение счетчика |
- Код должен быть 6-значным числом (от 100000 до 999999)
- При достижении максимума (999999) будет выброшено исключение
RuntimeException - Для каждого ключа счетчика хранится отдельное значение
MIT