在@OneToMany
JPA注释参考的示例部分中:
示例1-59 @OneToMany-具有泛型的客户类
@Entity
public class Customer implements Serializable {
...
@OneToMany(cascade=ALL, mappedBy="customer")
public Set<Order> getOrders() {
return orders;
}
...
}
示例1-60 @ManyToOne-具有泛型的Order类
@Entity
public class Order implements Serializable {
...
@ManyToOne
@JoinColumn(name="CUST_ID", nullable=false)
public Customer getCustomer() {
return customer;
}
...
}
在我看来,Customer
实体是协会的所有者。但是,在mappedBy
同一文档中对属性的说明中写道:
如果关系是双向的,则将关联的反(非所有权)侧的maptedBy元素设置为拥有该关系的字段或属性的名称,如示例1-60所示。
但是,如果我没有记错,则在示例中看起来,mappedBy
实际上是在关联的拥有方而不是非拥有方指定了。
所以我的问题基本上是:
在双向(一对多/多对一)关联中,所有者是哪个实体?我们如何指定一方为所有者?我们如何指定多方为所有者?
“关联的反面”是什么意思?我们如何将一侧指定为逆?我们如何将“多面”指定为反面?
要了解这一点,您必须退后一步。在OO中,客户拥有订单(订单是客户对象中的列表)。没有客户就无法下订单。因此,客户似乎是订单的所有者。
但是在SQL世界中,一项实际上将包含指向另一项的指针。由于N个订单有1个客户,因此每个订单都包含指向其所属客户的外键。这是“连接”,这意味着顺序“拥有”(或字面上包含)连接(信息)。这与OO
/模型世界完全相反。
这可能有助于了解:
public class Customer {
// This field doesn't exist in the database
// It is simulated with a SQL query
// "OO speak": Customer owns the orders
private List<Order> orders;
}
public class Order {
// This field actually exists in the DB
// In a purely OO model, we could omit it
// "DB speak": Order contains a foreign key to customer
private Customer customer;
}
反面是对象的OO“所有者”,在这种情况下是客户。客户在表中没有存储订单的列,因此您必须告诉它可以在订单表中的何处保存该数据(通过发生mappedBy
)。
另一个常见的示例是带有节点的树,这些节点可以是父母也可以是孩子。在这种情况下,两个字段在一个类中使用:
public class Node {
// Again, this is managed by Hibernate.
// There is no matching column in the database.
@OneToMany(cascade = CascadeType.ALL) // mappedBy is only necessary when there are two fields with the type "Node"
private List<Node> children;
// This field exists in the database.
// For the OO model, it's not really necessary and in fact
// some XML implementations omit it to save memory.
// Of course, that limits your options to navigate the tree.
@ManyToOne
private Node parent;
}
这解释了“外键”多对一设计的工作。第二种方法是使用另一个表来维护关系。这意味着,对于我们的第一个示例,您有三个表:一个有客户的表,一个有订单的表和一个带有两对主键(customerPK,orderPK)的两列表。
这种方法比上面的方法更灵活(它可以轻松处理一对一,多对一,一对多甚至多对多)。价格是
这就是为什么我很少推荐这种方法的原因。
我在将带有@ManyToOne关系的实体(雇员)映射到带有@OneToMany关系的实体(社区)时遇到了问题。 当我将一个实体(社区)分配给一个实体(员工),其中社区的值为空时,它工作正常。 问题出现了,如果雇员已经为社区分配了价值。当我更改该值并保存更改时,该员工为社区获得了新的值,并且这个新社区在集合中获得了该员工。唯一的问题是,老社区仍然有这个员工在收集,但它应该被删除。这只有在数据库重新启
问题内容: 我认为我误解了关系中级联的含义。 案子: 的含义是什么?例如,如果我从数据库中删除某个地址,添加的事实会如何影响我的数据(User我猜是)? 问题答案: 含义是,持久性会将所有操作()传播(层叠)到相关实体。 在你的情况下,似乎是个坏主意,因为删除会导致删除。由于用户可以具有多个地址,因此其他地址将成为孤立地址。但是,相反的情况(用注释)将是有道理的-如果一个地址仅属于一个用户,则删除
我想我误解了关系上下文中级联的含义。 案例:
问题内容: 假设我们具有以下实体: 在更新中可以理解,我们需要保持双方的关系如下: 到目前为止一切都很好。问题是,我是否应按以下所述在双方上进行合并,并且避免使用级联进行第二次合并? 还是合并拥有者足够?这些合并是否还应该在Transaction或EJB内部进行?还是在具有分离实体的简单控制器方法上完成它? 问题答案: 问题是,我是否应按以下所述在双方上进行合并,并且避免使用级联进行第二次合并?
7.4.1. 一对多(one to many)/多对一(many to one) 双向多对一关联 是最常见的关联关系。下面的例子解释了这种标准的父/子关联关系。 <class name="Person"> <id name="id" column="personId"> <generator class="native"/> </id> <many-to-
我正在尝试在 /addNewUser 终结点上使用以下 POST 请求创建新用户:- 发布请求 UserController类:- 用户服务类:- 用户存储库界面 但我得到了以下例外:- 用户模型类 AuthoritiesModel类:- 最初,我认为我的post请求或Jackson API的反序列化存在一些问题,所以我打印了控制器方法中UserModel字段的值,并且所有值都设置正确,包括Aut