<legend id='AIbL7'><style id='AIbL7'><dir id='AIbL7'><q id='AIbL7'></q></dir></style></legend>

  • <small id='AIbL7'></small><noframes id='AIbL7'>

      <bdo id='AIbL7'></bdo><ul id='AIbL7'></ul>
    <i id='AIbL7'><tr id='AIbL7'><dt id='AIbL7'><q id='AIbL7'><span id='AIbL7'><b id='AIbL7'><form id='AIbL7'><ins id='AIbL7'></ins><ul id='AIbL7'></ul><sub id='AIbL7'></sub></form><legend id='AIbL7'></legend><bdo id='AIbL7'><pre id='AIbL7'><center id='AIbL7'></center></pre></bdo></b><th id='AIbL7'></th></span></q></dt></tr></i><div id='AIbL7'><tfoot id='AIbL7'></tfoot><dl id='AIbL7'><fieldset id='AIbL7'></fieldset></dl></div>

  • <tfoot id='AIbL7'></tfoot>

        创建表时 MySQL 错误 1022

        MySQL error 1022 when creating table(创建表时 MySQL 错误 1022)

      1. <tfoot id='FQIvi'></tfoot>

          <bdo id='FQIvi'></bdo><ul id='FQIvi'></ul>
              <tbody id='FQIvi'></tbody>
            <i id='FQIvi'><tr id='FQIvi'><dt id='FQIvi'><q id='FQIvi'><span id='FQIvi'><b id='FQIvi'><form id='FQIvi'><ins id='FQIvi'></ins><ul id='FQIvi'></ul><sub id='FQIvi'></sub></form><legend id='FQIvi'></legend><bdo id='FQIvi'><pre id='FQIvi'><center id='FQIvi'></center></pre></bdo></b><th id='FQIvi'></th></span></q></dt></tr></i><div id='FQIvi'><tfoot id='FQIvi'></tfoot><dl id='FQIvi'><fieldset id='FQIvi'></fieldset></dl></div>
          1. <legend id='FQIvi'><style id='FQIvi'><dir id='FQIvi'><q id='FQIvi'></q></dir></style></legend>

                <small id='FQIvi'></small><noframes id='FQIvi'>

                1. 本文介绍了创建表时 MySQL 错误 1022的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  MySQL Workbench 想出了以下 SQL 来创建表:

                  MySQL Workbench came up with the following SQL to create a table:

                  CREATE  TABLE IF NOT EXISTS `mydb`.`errors_reports` (
                     `error_id` INT NOT NULL ,
                     `report_short` VARCHAR(15) NOT NULL ,
                  PRIMARY KEY (`error_id`, `report_short`) ,
                  INDEX `error_id_idx` (`error_id` ASC) ,
                  INDEX `report_short_idx` (`report_short` ASC) ,
                  CONSTRAINT `error_id`
                     FOREIGN KEY (`error_id` )
                     REFERENCES `mydb`.`errors` (`error_id` )
                     ON DELETE NO ACTION
                     ON UPDATE NO ACTION,
                  CONSTRAINT `report_short`
                     FOREIGN KEY (`report_short` )
                     REFERENCES `mydb`.`reports` (`report_short` )
                     ON DELETE NO ACTION
                     ON UPDATE NO ACTION)
                  ENGINE = InnoDB
                  

                  这对我来说看起来不错,而且我的数据库中还有一堆其他非常相似的表,MySQL 非常乐意创建这些表.

                  which looks fine to me, and there are a bunch of other very similar tables in my database which MySQL was perfectly happy to create.

                  但是这个...

                  ERROR 1022 (23000): Can't write; duplicate key in table 'errors_reports'
                  

                  我这辈子都看不到这里有任何重复的键.只定义了一个键!

                  I can't for the life of me see any duplicate keys here. There's only one key defined!

                  我正在使用全新的默认安装运行 MySQL 5.6.错误日志中没有任何内容.

                  I'm running MySQL 5.6 with a fresh default install. There's nothing in the error log.

                  想法?

                  通过消除过程(回到表的最简单的可能定义,然后逐渐添加位)问题似乎是这一点:

                  through a process of elimination (going back to the simplest possible definition of the table, then gradually adding bits back in) the problem appears to be this bit:

                  CONSTRAINT `error_id`
                      FOREIGN KEY (`error_id` )
                      REFERENCES `mydb`.`errors` (`error_id` )
                      ON DELETE NO ACTION
                      ON UPDATE NO ACTION,
                  

                  这特别奇怪,因为在其他几个表定义中有相同的代码,而且完全没问题!

                  which is particularly odd as there is identical code in several other table definitions and those are perfectly okay!

                  推荐答案

                  问题是外键名称不能相同 作为整个模型中的另一个外键.

                  The problem is that the name of a foreign key can not be the same as another foreign key in the entire model.

                  想象一下这种情况

                  目录 --> 供应商

                  产品 --> 供应商

                  如果表 Catalog 中供应商的外键名称为供应商",而您在产品表中分配了相同的名称,那么外键名称将冲突".

                  if the name of the foreign key in table Catalog for supplier is "supplier" and you assigned the same name in product table then the foreign keys names will "collide".

                  你需要给它们起不同的名字..

                  You need to name them differently..

                  例如:

                  catalog_supplier产品供应商

                  catalog_supplier product_supplier

                  这篇关于创建表时 MySQL 错误 1022的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Bogus foreign key constraint fail(虚假外键约束失败)
                  how to get last insert id after insert query in codeigniter active record(如何在codeigniter活动记录中插入查询后获取最后一个插入ID)
                  Force InnoDB to recheck foreign keys on a table/tables?(强制 InnoDB 重新检查表/表上的外键?)
                  How to auto generate migrations with Sequelize CLI from Sequelize models?(如何使用 Sequelize CLI 从 Sequelize 模型自动生成迁移?)
                  Clear MySQL query cache without restarting server(无需重启服务器即可清除 MySQL 查询缓存)
                  ALTER TABLE to add a composite primary key(ALTER TABLE 添加复合主键)
                    <bdo id='kw70T'></bdo><ul id='kw70T'></ul>
                  • <small id='kw70T'></small><noframes id='kw70T'>

                    <i id='kw70T'><tr id='kw70T'><dt id='kw70T'><q id='kw70T'><span id='kw70T'><b id='kw70T'><form id='kw70T'><ins id='kw70T'></ins><ul id='kw70T'></ul><sub id='kw70T'></sub></form><legend id='kw70T'></legend><bdo id='kw70T'><pre id='kw70T'><center id='kw70T'></center></pre></bdo></b><th id='kw70T'></th></span></q></dt></tr></i><div id='kw70T'><tfoot id='kw70T'></tfoot><dl id='kw70T'><fieldset id='kw70T'></fieldset></dl></div>

                        <tfoot id='kw70T'></tfoot>
                      1. <legend id='kw70T'><style id='kw70T'><dir id='kw70T'><q id='kw70T'></q></dir></style></legend>
                          <tbody id='kw70T'></tbody>