MySQL当中的修改外键关联主键字段属性

这个报错是因为 factory_goods (记得换成自己的表名称)表的 goods_iduser_app_order 表作为外键引用了,MySQL 不允许直接修改被外键关联的主键字段属性,需要先临时关闭外键约束,修改完成后再恢复。

1.完整的修改步骤(安全且可执行)

步骤 1:临时关闭外键约束

先登录 MySQL,执行以下命令关闭外键检查(仅当前会话有效,重启后自动恢复,不用担心影响其他业务):

sql

复制代码
SET FOREIGN_KEY_CHECKS = 0;
步骤 2:修改 goods_id 为自增

现在执行之前的修改语句,就能成功了:

sql

复制代码
ALTER TABLE factory_goods MODIFY COLUMN goods_id INT(11) NOT NULL AUTO_INCREMENT;
步骤 3:恢复外键约束

修改完成后,一定要恢复外键检查,保证数据完整性:

sql

复制代码
SET FOREIGN_KEY_CHECKS = 1;
步骤 4:验证修改结果

执行以下命令查看表结构,确认 goods_id 已经带有 auto_increment

sql

复制代码
DESC factory_goods;

如果输出中 goods_id 那一行的 Extra 列显示 auto_increment,就说明修改成功了。

2.关键说明

  • SET FOREIGN_KEY_CHECKS = 0 只是临时禁用外键检查,不会删除外键关系,只是允许你修改被引用的主键字段,修改完成后恢复即可,对现有数据和外键关联没有破坏。
  • 执行这些操作前,建议先备份数据库(比如 mysqldump -u 用户名 -p xingrong_db > backup.sql),防止误操作(虽然这个操作本身很安全)。
  • 修改完成后,记得把 Django 模型里的 goods_id = models.IntegerField(primary_key=True) 改成 goods_id = models.AutoField(primary_key=True),重启 Django 项目,新增数据时就会自动生成 goods_id 了。

3.总结

  1. 报错原因:goods_id 作为外键被其他表引用,无法直接修改自增属性。
  2. 解决核心:临时关闭外键约束 → 修改字段 → 恢复约束。
  3. 后续操作:同步修改 Django 模型的字段类型为 AutoField,解决 goods_id 为空的报错。

执行完这些步骤后,再在 Django 中新增商品数据,就不会再出现 Column 'goods_id' cannot be null 的错误了。

相关推荐
m0_6403093013 小时前
如何用SQL统计每组的平均值同时显示原行_OVER子句
jvm·数据库·python
qq_3721542313 小时前
Redis如何在应用启动时预热缓存数据
jvm·数据库·python
2601_9498153313 小时前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
解救女汉子13 小时前
CSS如何利用CSS变量进行渐变色管理_提升渐变配置的灵活性
jvm·数据库·python
杨云龙UP13 小时前
2000—CentOS Linux 7上部署Oracle 19c(19.3) RAC(RedHat/CentOS 7/8)
linux·运维·服务器·数据库·oracle·centos
m0_6784854513 小时前
怎么导入只包含特定表的SQL文件_正则提取与分离导入
jvm·数据库·python
星晨雪海13 小时前
若依框架原有页面功能进行了点位管理改造之列表查询(4)
数据库·sql·mybatis
历程里程碑13 小时前
MySQL事务深度解析:ACID到MVCC实战+万字长文解析
开发语言·数据结构·数据库·c++·sql·mysql·排序算法
橄榄熊13 小时前
docker MySQL 密码报错,重新修改保留原样的数据
mysql·docker·容器
NineData13 小时前
NineData 将亮相 2026 德国汉诺威工业博览会
数据库·人工智能·数据库管理工具·ninedata·数据库迁移工具·玖章算术