Incrementable Eloquent models
, (*1)
Define a custom auto-increment field in your Eloquent model, that is determined through PHP
rather than your database engine., (*2)
Furthermore, by making use of increment groups, you can restart counting in-table based on
other fields. Consider this example:, (*3)
| id |
code |
project_id |
| 1 |
1 |
1 |
| 2 |
2 |
1 |
| 3 |
3 |
1 |
| 4 |
1 |
2 |
| 5 |
2 |
2 |
Imagine a bug tracking application that stores each bug in a single table, but is represented
on a per-project basis. You'll want start each project with a fresh bug count, while maintaining
a unique database id. Incrementable will enable you to automatically reset the code counter
once a new project_id is defined., (*4)
Table of Contents
Installation
This package can be installed through Composer:, (*5)
$ composer require testmonitor/eloquent-incrementable
Usage
In order to add Incrementable to your Eloquent model, you'll need to:
, (*6)
- Use the trait
TestMonitor\Incrementable\Traits\Incrementable on your model(s).
- Configure the incrementable field (note: make sure its an integer column).
- Optionally, add one or more increment groups.
Add the Incrementable trait on the models you want to track:, (*7)
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use TestMonitor\Incrementable\Traits\Incrementable;
class Bug extends Model
{
use Incrementable, SoftDeletes;
protected $table = 'bugs';
protected $incrementable = 'code';
// This will cause the code to reset once
// a new project_id is found.
protected $incrementableGroup = ['project_id'];
}
In order to avoid collisions, Incrementable will preserve the count for a
soft-deleted model. Although this will cause a gap between this and the
next model, it will ensure uniqueness when the model is restored., (*8)
Examples
In this example, we have set up the following:, (*9)
- A table containing a
name and code field.
- An Eloquent model called
App\Bug, which uses the Incrementable trait
- A property on the Bug model:
$incrementable = 'code'
We can now run this example:, (*10)
$bug = new App\Bug(['name' => 'It doesn\'t work.']);
$bug->save();
// Will show '1'
echo $bug->code;
$bug = new App\Bug(['name' => 'It really doesn\'t work.']);
$bug->save();
// Will show '2'
echo $bug->code;
Tests
The package contains integration tests. You can run them using PHPUnit., (*11)
$ vendor/bin/phpunit
Changelog
Refer to CHANGELOG for more information., (*12)
Contributing
Refer to CONTRIBUTING for contributing details., (*13)
Credits
License
The MIT License (MIT). Refer to the License for more information., (*14)