使用 Hibernate 的 JPA 中的复合键
使用关系数据库时,可能需要将组合键映射到对象的 Java 类 -面向编程。在给定的代码中,时间表有一个由 levelStation 和 confPathID 组成的复合键。本文将指导您如何使用 JPA 和 Hibernate 以及 EmbeddedId 和 IdClass 注释来映射此复合键。
IdClass
IdClass 注释用于映射多个将各个字段合并为单个复合主键 (PK)。要实现此方法,请创建一个定义复合 PK 结构的静态内部类,并实现其 equals() 和 hashCode() 方法以进行正确的值比较。将此静态类中的相应字段与实体中的字段进行标识。
public class TimePK implements Serializable { protected Integer levelStation; protected Integer confPathID; // ... } @Entity @IdClass(TimePK.class) public class Time { @Id private Integer levelStation; @Id private Integer confPathID; // ... }
EmbeddedId
使用EmbeddedId注解,可以将复合PK封装为可嵌入的实体内的类。在可嵌入类中,定义构成复合 PK 的字段及其访问器。
@Embeddable public class TimePK { protected Integer levelStation; protected Integer confPathID; // ... } @Entity public class Time { @EmbeddedId private TimePK timePK; // ... }
差异
IdClass 和 EmbeddedId 注解都可以用于映射组合键,但它们的服务略有不同目的:
查询组合键
根据使用的注解,基于组合查询时需要的语法略有不同键:
IdClass
select t.levelStation from Time t
EmbeddedI d
select t.timePK.levelStation from Time t
参考文献
[JPA 1.0 规范](https://docs.oracle.com/javaee/7/api/javax/persistence/package-summary.html)
以上是如何使用'EmbeddedId”和'IdClass”在 Hibernate 中映射 JPA 中的复合键?的详细内容。更多信息请关注PHP中文网其他相关文章!