有点愚蠢的问题,但我没有在任何地方找到答案。 @Embeddable对象如何存储在数据库中,是一种带有FK的OneToOne还是......例如,如果我有:
@Entity
public class User {
private Long id;
@Id
public Long getId() { return id; }
public void setId(Long id) { this.id = id; }
private Address address;
@Embedded
public Address getAddress() { return address; }
public void setAddress() { this.address = address; }
}
@Embeddable
public class Address {
private String street1;
public String getStreet1() { return street1; }
public void setStreet1() { this.street1 = street1; }
}
表格应该如何?
答案 0 :(得分:2)
嵌入对象的字段作为列添加到拥有实体的表中。
因此,您将拥有一个包含字段User
和id
的表street1
。
答案 1 :(得分:1)
这非常简单:嵌入对象中的所有列都将合并到父级的列中,从而生成一个表。在您的示例中,您最终会得到一个包含列User
和id
的表street1
。因此,嵌入对象基本上是一种在一个表中对列进行逻辑分组的方法。