当前位置: 首页 > news >正文

JPA联合主键使用

在实际工作中,我们会经常遇到联合主键的情况,所以我用简单例子列举JPA两种实现联合主键的方式。

1、如何通过@IdClass 实现联合主键

第一步:新建一个UserInfoID类,里面是联合主键

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class UserInfoID implements Serializable {private String name, telephone;
}
​

第二步:新建一个UserInfo实体,采用@IdClass引用联合主键

@Entity
@Data
@Builder
@IdClass(UserInfoID.class)
@NoArgsConstructor
@AllArgsConstructor
public class UserInfo {private Integer ages;
​@Idprivate String name;@Idprivate String telephone;
}
​

第三步:新建一个UserInfoRepsitory类完成CRUD

@Repository
public interface UserInfoRepository  extends JpaRepository< UserInfo,UserInfoID> {
}
​

第四步:写一个测试

@SpringBootTest
class SpringDataJpaTestApplicationTests {
​
​@Resourceprivate UserInfoRepository userInfoRepository;
​@Testpublic void testIdClass() {userInfoRepository.save(UserInfo.builder().ages(29).name("sunfeng").telephone("18854885488").build());
​Optional<UserInfo> userInfoOptional = userInfoRepository.findById(UserInfoID.builder().name("sunfeng").telephone("18854885488").build());
​userInfoOptional.ifPresent(System.out::println);}
​
}
​

通过上面的例子可以发现表的主键是primary key(name, telephone),而Entity里面不是一个@Id字段了

2、@Embeddable与@EmbedDedId注解使用

第一步:我们在上面的例子中的UserInfoID里面添加@Embeddable注解

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
@Embeddable
public class UserInfoID implements Serializable {private String name, telephone;
}
​

第二步:修改一下我们刚才的UserInfo对象,删除@IdClass添加 @EmbeddedId注解

@Entity
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class UserInfo {private Integer ages;
​@EmbeddedIdprivate UserInfoID userInfoID;}
​

第三部:其他不变我们修改一下测试用例

​
@SpringBootTest
class SpringDataJpaTestApplicationTests {
​
​@Resourceprivate UserInfoRepository userInfoRepository;
​@Testpublic void testIdClass() {userInfoRepository.save(UserInfo.builder().ages(29).userInfoID(UserInfoID.builder().name("sunfeng").telephone("18854885488").build()).build());
​Optional<UserInfo> userInfoOptional = userInfoRepository.findById(UserInfoID.builder().name("sunfeng").telephone("18854885488").build());
​userInfoOptional.ifPresent(System.out::println);}

运行完之后,可以得到相同的结果。那么两种方式之间的区别是什么?

  1. 在使用的时候 @EmbeddedId使用的是对象,而IdClass用的是具体的字段

  2. 二者的JPQL也会不一样

    1. @IdClass的JPQL写法是:SELECT u.name FROM UserIndo u

    2. @EmbeddedId的JPQL写法是:select u.userInfo.name FROM UserInfo u

http://www.lryc.cn/news/209754.html

相关文章:

  • 【计算机毕设经典案例】基于微信小程序的图书管理系统
  • 如何制作rpm离线安装包
  • golang中快速用melody搭建轻量的websocket服务
  • ​Profinet转EtherNET/IP从站连接欧姆龙plc与西门子200smart通讯的配置方法​
  • elementUI el-table实现鼠标悬浮某一行,在鼠标右侧展示提示信息
  • Java 使用 poi 和 aspose 实现 word 模板数据写入并转换 pdf 增加水印
  • Spring Boot进阶(93):体验式教程:手把手教你整合Spring Boot和Zipkin
  • Lvs +keepalivede : 高可用集群
  • 得物 Redis 设计与实践yu
  • 优咔科技创新连接方案助力高质量5G车联服务
  • (a /b)*c的值
  • Hive 常用DML操作
  • centos部署tomcat
  • 【Spark】配置参数关系-重要
  • [Qt之“MMM dd yyyyhh:mm:ss“]时间格式
  • SSM宾馆客房管理系统开发mysql数据库web结构java编程计算机网页源码eclipse项目
  • 永远在路上
  • JS递归函数详解
  • JS问题:如何实现文本一键复制和长按复制功能?
  • react实现步进器
  • 【jenkins】centos7在线安装jenkins
  • Hive常用DDL操作
  • 关于css中设置变量用于全局Css或者Js中使用
  • Elasticsearch(十五)搜索---搜索匹配功能⑥--基于地理位置查询
  • 为什么axios会有params和data两个参数
  • Vite+Vue3项目全局引入scss文件
  • android10.0(Q) MTK 6765 user版本打开root权限
  • 软考 系统架构设计师系列知识点之设计模式(9)
  • LeetCode二分查找
  • 米软科技客户单病种上报量云南省第一