oracle

Oracle JPA中如何定义复合主键

小樊
82
2024-09-27 20:14:47
栏目: 云计算

在Oracle JPA中,要定义一个复合主键,您需要遵循以下步骤:

  1. 创建一个实体类,该实体类将表示数据库中的表。
import javax.persistence.*;

@Entity
@Table(name = "my_table")
public class MyEntity {
    // 复合主键的代码将在这里定义
}
  1. 在实体类中,使用@IdClass注解来定义复合主键类。首先,创建一个包含所有主键字段的简单Java类。
import java.io.Serializable;
import java.util.Objects;

public class MyCompositeKey implements Serializable {
    private Long field1;
    private Long field2;

    // 生成getter和setter方法
    // ...

    // 重写equals和hashCode方法,以便在比较主键时能够正确识别
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        MyCompositeKey that = (MyCompositeKey) o;
        return Objects.equals(field1, that.field1) &&
                Objects.equals(field2, that.field2);
    }

    @Override
    public int hashCode() {
        return Objects.hash(field1, field2);
    }
}
  1. 在实体类中,使用@IdClass注解来指定复合主键类。
import javax.persistence.*;

@Entity
@Table(name = "my_table")
@IdClass(MyCompositeKey.class)
public class MyEntity {
    @Id
    private Long field1;

    @Id
    private Long field2;

    // 其他字段和getter/setter方法
    // ...
}

现在,您已经成功地在Oracle JPA中定义了一个复合主键。请注意,这种方法仅适用于单个表。如果您需要在多个表之间定义复合主键,您可能需要考虑使用@Embeddable@EmbeddedId注解。

0
看了该问题的人还看了