当前位置: 首页 > 知识库问答 >
问题:

使用关系外键进行Hibernate更新

梁研
2023-03-14
dao.persist(A);
Error org.hibernate.TransientPropertyValueException: object references an unsaved transient instance

我如何才能做到这一点,使我的A实体仅由B的外键持久化?也就是说,只有外键被插入到数据库中(因为B是一个主表,所以我不需要插入元素)。

共有1个答案

东弘扬
2023-03-14

您需要将关系的两侧设置为在双向关系中正确处理级联。

即对于Onetotone:

a.setB(b);
b.setA(b);

一个托马尼:

a.setB(b);
b.getAs().add(a);
 类似资料:
  • 问题内容: 我是RestKit的新手,正在挣扎。 JSON: 核心数据: 我的应用程序逻辑如下所示: 我一生都无法解决如何使RestKit填充用户对象的团队Property的问题。 我看过这么多帖子,但是我没有尝试,这不是通常的用例吗? 有谁知道该怎么做,帮助将不胜感激! 谢谢。 问题答案: 您需要向持有关联的实体添加一个临时属性。这需要添加到您的中。 然后,您需要为您添加一个关系定义: 这将为R

  • 我有表,和,一个用户有很多帖子,每个帖子有很多评论(在评论表中),还有一个用户有很多评论,但不完全需要匿名用户(在评论表中),下面的代码为每个帖子播种一些评论,但user_id从不由评论的所有者填写。我希望评论有相关的user_id注入数组外面

  • 我做了一个图书馆管理系统。我正试图打印学生问题书,但SQL查询遇到了问题。下面是用户。用于打印发行书籍的php代码。我也上传了数据库,方便大家参考。请帮忙。 使用者php 以下是图书馆管理系统的数据库。 数据库是这样关联的:-usertable将id作为主键。Book将isbn作为主键,bookid作为外键。类型将bookid作为主键。存折的外键为isbn,主键为uid。我想显示存折,其中会显示存

  • 问题内容: 我有两个非常简单的对象,并且一个对象应在一组“一对多”关系中包含另一个对象。对象已正确插入数据库中,但“子项”表中的外键始终为“ null”。 我不知道为什么: 这是测试对象,它将子对象保持在其集合中: 这是子对象,它包含指向“ TestObj”的反向链接: 我使用以下代码来持久化此对象: 有人可以解释一下为什么会这样吗? 问题答案: 这很简单:您永远不会初始化中的字段(应将其命名为C

  • 我们系统的所有用户都来自一个主“用户”类。同样,我们希望以相同的方式构造数据库,拥有一个主“用户”表,该表与特定用户类型的必要表连接,以提供额外的用户信息。 以这三个基本表格为例: 表用户 user_id|user_email|user_firstname|user_lastname|... 表雇员 user_id|employee_staff_number|... 表管理 user_id|adm

  • 我试图使用Hibernate注释定义遗留数据库中两个实体之间的映射。考虑中的实体不共享外键/复合键,此时,修改旧表是不可能的选择:( 实体类似于以下实体; 如果查看该表,它们不维护任何外键关系,也不共享相同的复合键,唯一的共同因素是zip\U code和school\U name列。我希望使用HIBERNATE注释定义与学校相对应的实体类,以便每次从DB检索学校的实体时,我还希望获得与该学校相关联