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-uuidThis 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.md
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:cachePer-model override still works and takes precedence:
protected $uuidColumn = 'custom_uuid';Run this command if you want to check unit tests:
./vendor/bin/phpunitOr if you want to check code coverage:
phpdbg -qrr vendor/bin/phpunit --coverage-html coverage tests