Field 'id' doesn't have a default value


首先原因在于没有设置主键自增长。

mysql的自增长模式是IDENTITY。

jpa标签:

@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)

 

设置主键自增长后,重启项目,要注意数据库里面主键生成模式是否真实被改变了。

navicat下很方便看到:

如果没有改变,查看无法改写的原因。

如果报错如此:

 

Cannot change column id used in a foreign key constraint

则表明因为外键的存在而无法改写

要想更改表结构,首先要把基层的表修改了。

A表 作为B表的外键,A表不能随便修改。

B表 有A表的外键,必须先处理好B,然后A才能修改。

所以建表的一开始就应该注明主键生成策略。

否则就把外键删除再来吧。

 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM