Ordered binary UUID in Laravel / Eloquent based on UUID version 1
verbanent/eloquent-binary-uuid is a Laravel package for ordered binary uuid in laravel / eloquent based on uuid version 1.
It currently has 3 GitHub stars and 11.324 downloads on Packagist (latest version v1.10.0).
Install it with composer require verbanent/eloquent-binary-uuid.
Discover more Laravel packages by verbanent
or browse all Laravel packages to compare alternatives.
Last updated
Based on articles about the optimization of UUID storage in databases, I decided to write a simple library that allows this in my projects. I based on the information available here:
https://www.percona.com/blog/2014/12/19/store-uuid-optimized-way/
https://percona.community/blog/2018/10/12/generating-identifiers-auto_increment-sequence/
The package currently only supports MySQL.
Please install the package via Composer:
composer require verbanent/eloquent-binary-uuid
This example keeps things simple: Foo and Bar both use UUID primary keys,
and Bar.foo_id references Foo.id.
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
Schema::create('foos', function (Blueprint $table) {
$table->uuid('id')->primary();
$table->string('name')->nullable();
$table->timestamps();
});
Schema::create('bars', function (Blueprint $table) {
$table->uuid('id')->primary();
$table->uuid('foo_id');
$table->string('title')->nullable();
$table->timestamps();
$table->foreign('foo_id')->references('id')->on('foos')->cascadeOnDelete();
});
namespace App\Models;
use Verbanent\Uuid\AbstractModel;
class Foo extends AbstractModel
{
protected $fillable = ['name'];
public function bars()
{
return $this->hasMany(Bar::class, 'foo_id');
}
}
namespace App\Models;
use Verbanent\Uuid\AbstractModel;
use Verbanent\Uuid\Traits\ForeignBinaryUuidSupportableTrait;
class Bar extends AbstractModel
{
protected $fillable = ['title'];
public function foo()
{
return $this->belongsTo(Foo::class, 'foo_id');
}
}
$foo = \App\Models\Foo::create(['name' => 'Alpha']);
$bar = new \App\Models\Bar(['title' => 'Child']);
$bar->foo()->associate($foo);
$bar->save();
More scenarios are documented in the examples/ directory:
examples/01-single-model-uuid-primary-key.mdexamples/02-two-models-uuid-pk-and-fk.mdexamples/03-creating-entities-with-binary-uuid.mdexamples/04-creating-entities-with-string-uuid.mdexamples/05-querying.mdIf you want a global default UUID column name, publish the config and set the environment variable.
php artisan vendor:publish --provider="Verbanent\\Uuid\\Providers\\BinaryUuidServiceProvider" --tag=binary-uuid-config
.env:BINARY_UUID_DEFAULT_COLUMN=uuid
php artisan config:clear
# or
php artisan config:cache
Per-model override still works and takes precedence:
protected $uuidColumn = 'custom_uuid';
Run this command if you want to check unit tests:
./vendor/bin/phpunit
Or if you want to check code coverage:
phpdbg -qrr vendor/bin/phpunit --coverage-html coverage tests