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

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

    <legend id='ojY4D'><style id='ojY4D'><dir id='ojY4D'><q id='ojY4D'></q></dir></style></legend>
    • <bdo id='ojY4D'></bdo><ul id='ojY4D'></ul>

        <tfoot id='ojY4D'></tfoot>

        无法更改外键约束中使用的列

        Cannot change column used in a foreign key constraint(无法更改外键约束中使用的列)
        • <bdo id='6VGua'></bdo><ul id='6VGua'></ul>
          <legend id='6VGua'><style id='6VGua'><dir id='6VGua'><q id='6VGua'></q></dir></style></legend>

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

                    <tbody id='6VGua'></tbody>

                1. 本文介绍了无法更改外键约束中使用的列的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  限时送ChatGPT账号..

                  当我试图改变我的表格时出现了这个错误.

                  I got this error when i was trying to alter my table.

                  Error Code: 1833. Cannot change column 'person_id': used in a foreign key constraint 'fk_fav_food_person_id' of table 'table.favorite_food'
                  

                  这是我成功运行的 CREATE TABLE STATEMENT.

                  Here is my CREATE TABLE STATEMENT Which ran successfully.

                  CREATE TABLE favorite_food(
                      person_id SMALLINT UNSIGNED,
                      food VARCHAR(20),
                      CONSTRAINT pk_favorite_food PRIMARY KEY(person_id,food),
                      CONSTRAINT fk_fav_food_person_id FOREIGN KEY (person_id)
                      REFERENCES person (person_id)
                  );
                  

                  然后我尝试执行此语句,但出现上述错误.

                  Then i tried to execute this statement and i got the above error.

                  ALTER TABLE person MODIFY person_id SMALLINT UNSIGNED AUTO_INCREMENT;
                  

                  推荐答案

                  外键字段和引用的类型和定义必须相同.这意味着您的外键不允许更改您的字段类型.

                  The type and definition of foreign key field and reference must be equal. This means your foreign key disallows changing the type of your field.

                  一种解决方案是:

                  LOCK TABLES 
                      favorite_food WRITE,
                      person WRITE;
                  
                  ALTER TABLE favorite_food
                      DROP FOREIGN KEY fk_fav_food_person_id,
                      MODIFY person_id SMALLINT UNSIGNED;
                  

                  现在您可以更改您的 person_id

                  Now you can change you person_id

                  ALTER TABLE person MODIFY person_id SMALLINT UNSIGNED AUTO_INCREMENT;
                  

                  重新创建外键

                  ALTER TABLE favorite_food
                      ADD CONSTRAINT fk_fav_food_person_id FOREIGN KEY (person_id)
                            REFERENCES person (person_id);
                  
                  UNLOCK TABLES;
                  

                  在上面添加了锁,感谢评论

                  Added locks above, thanks to comments

                  在执行此操作时,您必须禁止写入数据库,否则,您将面临数据完整性问题的风险.

                  You have to disallow writing to the database while you do this, otherwise you risk data integrity problems.

                  我在上面添加了写锁

                  除您自己的会话(INSERT、UPDATE、DELETE)之外的任何其他会话中的所有写入查询都将等到超时或UNLOCK TABLES;被执行

                  All writing queries in any other session than your own ( INSERT, UPDATE, DELETE ) will wait till timeout or UNLOCK TABLES; is executed

                  http://dev.mysql.com/doc/refman/5.5/en/lock-tables.html

                  编辑 2:OP 要求更详细地解释外键字段和引用的类型和定义必须相同.这意味着您的外键不允许更改您的字段类型."

                  EDIT 2: OP asked for a more detailed explanation of the line "The type and definition of foreign key field and reference must be equal. This means your foreign key disallows changing the type of your field."

                  来自 MySQL 5.5 参考手册:FOREIGN KEY约束

                  外键和引用的键中对应的列必须InnoDB 内部具有相似的内部数据类型,以便它们可以比较没有类型转换.整数类型的大小和符号必须相同.字符串类型的长度不必相同.为了非二进制(字符)字符串列、字符集和排序规则必须相同.

                  Corresponding columns in the foreign key and the referenced key must have similar internal data types inside InnoDB so that they can be compared without a type conversion. The size and sign of integer types must be the same. The length of string types need not be the same. For nonbinary (character) string columns, the character set and collation must be the same.

                  这篇关于无法更改外键约束中使用的列的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

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

                  相关文档推荐

                  Can#39;t Create Entity Data Model - using MySql and EF6(无法创建实体数据模型 - 使用 MySql 和 EF6)
                  MySQL select with CONCAT condition(MySQL选择与CONCAT条件)
                  Capitalize first letter of each word, in existing table(将现有表格中每个单词的首字母大写)
                  How to retrieve SQL result column value using column name in Python?(如何在 Python 中使用列名检索 SQL 结果列值?)
                  Update row with data from another row in the same table(使用同一表中另一行的数据更新行)
                  Exporting results of a Mysql query to excel?(将 Mysql 查询的结果导出到 excel?)

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

                      <legend id='FO2iM'><style id='FO2iM'><dir id='FO2iM'><q id='FO2iM'></q></dir></style></legend>
                      • <tfoot id='FO2iM'></tfoot>

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