清风半夜鸣蛙 2019-12-31 15:21 采纳率: 100%
浏览 1544
已采纳

Springboot启动时报错:Caused by: java.sql.SQLSyntaxErrorException: ORA-02275: 此表中已经存在这样的引用约束条件。关于JPA的使用

使用的是Oracle数据库,
在数据库中我已经创建好了表,表之间的主外键关系我是手动来创建的。
userrolerecid references md_role(recid) not null,
userclassrecid references md_class(recid) not null ,
类似这样的关系。
然后在使用jpa的时候 我是这样创建bean的

@OneToOne(cascade=CascadeType.ALL) //级联操作
@JoinColumn(name="userrolerecid",referencedColumnName="recid")
private RoleInfo roleInfo;

@OneToOne(cascade=CascadeType.ALL) //级联操作
@JoinColumn(name="userclassrecid",referencedColumnName="recid")
private ClassInfo classInfo;

然后就报类似于这样的错误
Caused by: java.sql.SQLSyntaxErrorException: ORA-02275: 此表中已经存在这样的引用约束条件
请问怎么解决?
  • 写回答

1条回答 默认 最新

  • 程序员的救赎 2019-12-31 16:04
    关注

    自动创建的主外键约束和你手动创建的主外键约束冲突了

    JPA在你配置了@OneToOne等约束条件后,会自动帮你创建约束,所以你不需要手动自己创建。

    需要将jpa的ddl-auto修改成update

    spring.jpa.hibernate.ddl-auto=update
    

    字段间的约束有数据库建立约束、数据库不建立约束在代码里用代码逻辑维护。
    jpa里使用的是第三种,在代码里由代码和注解维护约束并由jpa自动去维护数据库中的约束,解放程序员!

    祝你好运!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同