carva / id-to-uuid
Easily migrate from auto incremented id to uuid
dev-master
2023-03-10 20:19 UTC
Requires
- php: ^8.0
- doctrine/dbal: ^2.9
- doctrine/doctrine-migrations-bundle: ^3.2
- doctrine/orm: ^2.13
- ramsey/uuid-doctrine: 1.6.*
Requires (Dev)
This package is not auto-updated.
Last update: 2025-03-23 01:16:24 UTC
README
Easily migrate from an auto incremented integer id to a uuid in a project using DoctrineMigrationsBundle. Autodetect your foreign keys and update them. Works only on MySQL.
Installation
composer require habbim/id-to-uuid
Usage
- Update your
id
column frominteger
toguid
:
# User.orm.xml <entity name="AppBundle\Entity\User" table="user"> --- <id name="id" column="id" type="integer"> --- <generator strategy="AUTO" /> +++ <id name="id" column="id" type="uuid_binary_ordered_time"> +++ <generator strategy="CUSTOM"/> +++ <custom-id-generator class="Ramsey\Uuid\Doctrine\UuidGenerator"/> </id> #... </entity>
- Config your symfony:
- Add a new migration:
// app/DoctrineMigrations/VersionXYZ.php <?php namespace Application\Migrations; use Doctrine\DBAL\Schema\Schema; use Habbim\IdToUuid\IdToUuidMigration; class VersionXYZ extends IdToUuidMigration { public function postUp(Schema $schema) { $this->migrate('user'); } }