如何在 Symfony 3 中使用 Doctrine 在类型 "json_array" 的列中添加复合索引?



我有一个表,我想添加这样的索引:

 @Index(columns={"child_id", "abilities"}),
 @Index(columns={"parent_id", "abilities"}),

 * @ORMColumn(type="json_array", length=256)
 */
protected $abilities;

但是,即使在迁移中添加了适当的限制后:

$this->addSql('CREATE INDEX IDX_1088BF61DD62C21BB8388DA4 ON xxx (child_id, abilities(512))');
$this->addSql('CREATE INDEX IDX_1088BF61727ACA70B8388DA4 ON xxx (parent_id, abilities(512))');

运行测试时会发生这样的错误,这些测试会重新创建数据库:

执行">

CREATE TABLE xxx (
    id INT AUTO_INCREMENT NOT NULL, 
    parent_id INT DEFAULT NULL, 
    child_id INT DEFAULT NULL, 
    type VARCHAR(125) NOT NULL, 
    abilities LONGTEXT NOT NULL COMMENT '(DC2Type:json_array)', 
    created_at DATETIME NOT NULL, 
    modified_at DATETIME NOT NULL, 
    INDEX IDX_1088BF61727ACA70 (parent_id), 
    INDEX IDX_1088BF61DD62C21B (child_id), 
    INDEX IDX_1088BF61DD62C21B8CDE5729 (child_id, type), 
    INDEX IDX_1088BF61727ACA708CDE5729 (parent_id, type), 
    INDEX IDX_1088BF618CDE5729 (type), 
    INDEX IDX_1088BF61DD62C21BB8388DA4 (child_id, abilities), 
    INDEX IDX_1088BF61727ACA7 0B8388DA4 (parent_id, abilities), 
    INDEX IDX_1088BF61B8388DA4 (abilities), 
    UNIQUE INDEX UNIQ_1088BF61727ACA70DD62C21B (parent_id, child_id), 
    PRIMARY KEY(id)
) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB

':

SQLSTATE[42000]:语法错误或访问冲突:1170 BLOB/文本 键规范中使用的列"能力",不带键长度

成功在这些列上创建索引,我需要做什么?

索引长字符串存在限制。

由于有问题的字符串包含"json",因此在该列上具有常规索引是没有用的。

解决方案:删除以下 3 个索引:

INDEX IDX_1088BF61DD62C21BB8388DA4 (child_id, abilities), 
INDEX IDX_1088BF61727ACA7 0B8388DA4 (parent_id, abilities), 
INDEX IDX_1088BF61B8388DA4 (abilities), 

最新更新