java.sql.SQLException: Field 'id' doesn't have a default value

本文探讨了在使用Hibernate进行持久化操作时,遇到的关于entity主键id没有默认值导致的java.sql.SQLException问题。详细解释了原因并提供了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在调用hiernate的save方法时,抛出如下错误:

java.sql.SQLException: Field 'id' doesn't have a default value

 

原因:

hibernate指定entity的id增长为GeneratedValue

@Id
	@GeneratedValue
	@Column(name = "ID")
	public Integer getId() {
		return this.id;
	}

 

它表示由数据库来自动生成主键值,但在创建数据库时并没有指定该字段的默认值。

 

如果把这句去掉,在save前手动指定entity的id,即可保存成功。

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值