Hibernate报错 Cannot add foreign key constraint

在尝试使用Hibernate执行DDL添加外键约束时遇到错误:'Cannot add foreign key constraint'。问题源于试图在picture_info表中添加一个引用base64file表的外键。通过参考CSDN上的文章,解决方案是在实体类中添加一行代码,具体操作是在getBase64File()方法上方,这暂时解决了报错问题,但可能有未知副作用。
摘要由CSDN通过智能技术生成

GenerationTarget encountered exception accepting command : Error executing DDL “alter table picture_info add constraint FK2ff6f2f6dg6av1beayxujnunm foreign key (base64file_id) references base64file (id)” via JDBC Statement
org.hibernate.tool.schema.spi.CommandAcceptanceException: Error executing DDL “alter table picture_info add constraint FK2ff6f2f6dg6av1beayxujnunm foreign key (base64file_id) references base64file (id)” via JDBC Statement
Caused by: java.sql.SQLException: Cannot add foreign key constraint

原因:
添加了一个一对一的表格外键如下:

@Entity
@ApiModel(description = "图片详情")
public class PictureInfo extends BasePerson {
 	private boolean enabled = false;
	private Base64File base64File;

	@OneToOne(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
	@ApiModelProperty("Base64文件对象")
	public Base64File getBase64File() {
    	return base64File;
	}

解决办法

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值