verbanent / eloquent-binary-uuid
Ordered binary UUID in Laravel / Eloquent based on UUID version 1
Installs: 11 043
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 3
Open Issues: 1
pkg:composer/verbanent/eloquent-binary-uuid
Requires
- php: ^7.3|^8
- ramsey/uuid: ^3.8|^4
Requires (Dev)
- laravel/framework: ^6.20.26|^7|^8|^9|^10.48.29|^11|^12
- mockery/mockery: ^1
- phpunit/phpunit: ^9
README
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.
Installation
Please install the package via Composer:
composer require verbanent/eloquent-binary-uuid
Basic example
This example keeps things simple: Foo and Bar both use UUID primary keys,
and Bar.foo_id references Foo.id.
Migrations
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(); });
Models
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'); } }
Usage
$foo = \App\Models\Foo::create(['name' => 'Alpha']); $bar = new \App\Models\Bar(['title' => 'Child']); $bar->foo()->associate($foo); $bar->save();
Examples
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.md
Configuration
If you want a global default UUID column name, publish the config and set the environment variable.
- Publish the config file:
php artisan vendor:publish --provider="Verbanent\\Uuid\\Providers\\BinaryUuidServiceProvider" --tag=binary-uuid-config
- Set the default column name in
.env:
BINARY_UUID_DEFAULT_COLUMN=uuid
- Refresh config:
php artisan config:clear
# or
php artisan config:cache
Per-model override still works and takes precedence:
protected $uuidColumn = 'custom_uuid';
Unit tests
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