学说表migrations_versions列长

问题描述

在带有学说迁移2.2.0的Symfony 5上,我想执行一个自定义学说迁移文件。 我的实体是使用InnoDB utf8mb4_unicode_ci(docctrine.yaml中的认值)创建的。

执行bin/console doctrine:migrations:status --show-versions时得到:

An exception occurred while executing 'CREATE TABLE migration_versions (version VARCHAR(1024) NOT NULL,executed_at DATETIME NOT NULL COMMENT '(DC2Type:datetime_immutable)',PRIMARY KEY(version)) DEFAULT CHaraCTER SET utf8mb4 COLLATE utf8mb4_unicode_ci ENGINE = InnoDB':
sqlSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 3072 bytes

所以我修改了doctrine_migrations.yaml并将version_column_length的值更改为255,但是现在我得到的命令相同

In BaseNode.PHP line 425:                                                                                                                                
Invalid configuration for path "doctrine_migrations.storage.table_storage.version_column_length": The minimum length for the version column is 1024.  
                                                                                                                                                        
In ExprBuilder.PHP line 187:
The minimum length for the version column is 1024.  

可以将自动创建的实体表的varchar长度更改为1024,因此这不是我的数据库的限制。 如何自动创建具有适当列长的migrations_versions表?

config / packages / doctrine.yaml

doctrine:
    dbal:
        url: '%env(resolve:DATABASE_URL)%'
        mapping_types:
          enum: string

        # IMPORTANT: You MUST configure your server version,# either here or in the DATABASE_URL env var (see .env file)
        #server_version: '5.7'
    orm:
        auto_generate_proxy_classes: true
        naming_strategy: doctrine.orm.naming_strategy.underscore_number_aware
        auto_mapping: true
        mappings:
            App:
                is_bundle: false
                type: annotation
                dir: '%kernel.project_dir%/src/Entity'
                prefix: 'App\Entity'
                alias: App

config / packages / doctrine_migrations.yaml

doctrine_migrations:
    migrations_paths:
        'DoctrineMigrations': '%kernel.project_dir%/src/Migrations'
    storage:
        table_storage:
            table_name: 'migration_versions'
            version_column_name: 'version'
            version_column_length: 1024
            executed_at_column_name: 'executed_at'

解决方法

我的同事通过简单地注释以下行找到了解决方案 version_column_length: 1024

,

发生这种情况是因为所使用的MySQL版本中的密钥长度受到限制。使用旧版本的MySQL可能会少一些,并且还取决于所使用的排序规则。您必须与正在使用的MySQL版本进行核对,以找到允许的最大键长度,然后找到可以与正在使用的排序规则一起使用的列的最大大小。该长度可以在学说迁移的配置文件中的选项 version_column_length 中使用(例如:migrations.php或migrations.xml等)。

可以在以下问题的答案中找到有关密钥最大长度的很好的解释。

Specified key was too long; max key length is 767 bytes

在我的情况下,限制为191,因为我使用的是MySQL 5.6