mysql报错1075: there can be only one auto column and it must be defined *主键外键均自动递增冲突

文章讲述了在MySQL中遇到错误1075,该错误通常由于表中有多个自动递增属性导致。作者通过将表A中引用表B主键的外键更新策略改为restrict,避免了两个表的type_id连锁更新,并取消了表A中type_id的自动递增属性,成功解决了问题。强调了一个表只能有一个自动递增主键的原则。
摘要由CSDN通过智能技术生成

最近写mysql遇到了报错1075,意思就是你这个表中可能有多个属性设置了自动递增,但是mysql只允许只有一个属性即主键可以自动递增。但是我的情况是这样的:表a的主键id是自动递增的,表b的主键type_id也是自动递增的,但是表a引用了表b的type_id作为外键,那么这就意味着表a中的type_id因为做外键所以也要自动递增,那么表a就有两个自动递增的属性了,所以就报错1075

那么我是怎么解决这个问题的呢?在外键配置中把更新的cascade改为restrict,这样两个表中的type-id在更新时可以不连锁在一起,这个时候把表a的type_id的自动递增属性取消勾选保存,就不报错啦!

总之,一个表只能一个属性自动递增且它一定要是主键,这一原则是不能违背的!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哈啰cool狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值