介绍
工作中使用的是JPA
作为持久化管理,跟之前使用的mybatis
不太一样,因为他有自己的HQL
语言,能根据方法签名自动推断sql
。只要在entity
实例中配置好@Id
,这个就是主键,很多方法都会根据这个来进行推断,比如save
方法,这个方法实际有两个工作:insert
和update
,具体区分方法就是先去数据库根据配置好的主键查询数据,如果没有就进行insert
,有的话就进行update
。
问题是联合主键怎么办,是没办法配置多个的
@Id
的,编译就会报错。
解决
联合主键JPA是有相关的配置的。具体有两种方法
- 使用
@IdClass
,就是新定义一个主键类,这里面所有的属性跟你的联合主键对应,且类型要保持一致,不然会报错。IdClass
如下:
@Data @AllArgsConstructor @NoArgsConstructor public class EntityIdClass implements Serializable { private Integer id1; private Integer id2; private String id3; private String id4; }
entity
如下:
@Data
@Entity
@Table(name = "DBTable")
@IdClass(EntityIdClass.class)
public class Entity {
@Column(name = "id3")
private String id3;
@Column(name = "id1")
private Integer id1;
@Column(name = "id2")
private Integer id2;
@Column(name = "id4")
private String id4;
@Column(name = "column1")
private String column1;
}
这个时候注解
@Id
是没有用的,你加不加是无所谓的,会以@IdClass
里面的为准。
- 使用@EmbeddedId与@Embeddable
@Data
@AllArgsConstructor
@NoArgsConstructor
@Embeddable
public class EntityIdClass implements Serializable {
private Integer id1;
private Integer id2;
private String id3;
private String id4;
}
@Data
@Entity
@Table(name = "DBTable")
@IdClass(EntityIdClass.class)
public class Entity {
@EmbeddedId
private EntityIdClass id;
@Column(name = "column1")
private String column1;
}
这样就可以直接使用了。
因为我想使用联合主键的部分属性,不想连环调用,所以采用的第一种方式。