Spring Data JPA 建立表的联合主键
最近遇到了一个小的问题,就是怎么使用SpringDataJPA建立表的联合主键?然后探索出了下面的两种方式。
第一种方式:
第一种方式是直接在类属性上面的两个字段都加上@Id注解,就像下面这样,给stuNo和stuName这两个字段加上联合主键:
@Entity @Table(name="student") publicclassStudent{ @Id @Column(name="stu_no",nullable=false,length=11) privateIntegerstuNo; @Id @Column(name="stu_name",nullable=false,length=128) privateStringstuName; @Column(name="stu_age",nullable=false,length=3) privateIntegerstuAge; @Column(name="class_id",nullable=false,length=8) privateStringclassId; }
只不过需要注意的是,实体类需要实现Serializable接口。
这种方式不是很好,虽然可以成功的创建表,但是使用JpaRepository的时候,需要指定主键ID的类型,这时候就会报错,所以使用第二种方式更好。
第二种方式:
实现起来也很简单,我们需要新建一个类,还是以stuNo和stuName建立联合主键,这个类需要实现Serializable接口。
publicclassStudentUPKimplementsSerializable{ privateIntegerstuNo; privateStringstuName; }
然后在实体类Student上面加上@IdClass注解,两个字段上面还是加上@Id注解:
@Entity @IdClass(StudentUPK.class) @Table(name="student") publicclassStudent{ @Id @Column(name="stu_no",nullable=false,length=11) privateIntegerstuNo; @Id @Column(name="stu_name",nullable=false,length=128) privateStringstuName; @Column(name="stu_age",nullable=false,length=3) privateIntegerstuAge; @Column(name="class_id",nullable=false,length=8) privateStringclassId; }
这样就能成功的创建表了,而且在使用JpaRepoistory的时候,可以指定主键为那个StudentUPK类,就像这样:publicinterfaceStudentRepositoryextendsJpaRepository
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。