cap-collectif / id-to-uuid
Easily migrate from auto incremented id to uuid
Installs: 66 843
Dependents: 0
Suggesters: 0
Security: 0
Stars: 17
Watchers: 17
Forks: 15
Open Issues: 4
Requires
- doctrine/dbal: ^2.5
- doctrine/doctrine-migrations-bundle: ~1.1 | ~2
- doctrine/orm: ^2.5
Requires (Dev)
Suggests
- ramsey/uuid: *
This package is not auto-updated.
Last update: 2025-03-05 19:11:00 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. Supported databases: MySQL, Postgres.
Installation
composer require cap-collectif/id-to-uuid
# install for postgres support
composer require ramsey/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="guid"> +++ <generator strategy="UUID" /> </id> #... </entity>
Alternatively you can use uuid-doctrine to add uuid
type support.
<id name="id" type="uuid" />
- Add a new migration:
// app/DoctrineMigrations/VersionXYZ.php <?php namespace Application\Migrations; use Doctrine\DBAL\Schema\Schema; use CapCollectif\IdToUuid\IdToUuidMigration; class VersionXYZ extends IdToUuidMigration //or PostgresIdToUuidMigration { public function postUp(Schema $schema): void { $this->migrate('user'); } }
Alternatively you can specify second parameter to migrate
method - custom temporary uuid field name
- After migration
Check if your db structure is different from the doctrine schema. If it does then create another migration or merge with the previous one.
bin/console doctrine:schema:update --dump-sql
bin/console doctrine:migration:diff