全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

SpringBoot JPA 表关联查询实例

今天给大家介绍一下如何利用JPA实现表关联查询。

今天给大家举一个一对多的关联查询,并且是使用JPA原生的findBy语句实现的。

例子中总共有两个实体类,一个是Floor(商品楼层类),另一个是FloorContent(商品楼层内容表)。下面看两张表的源代码:

Floor类:

package cms.model; 
import cms.model.base.BaseDomain; 
import org.hibernate.annotations.GenericGenerator; 
 
import javax.persistence.*; 
import java.io.Serializable; 
import java.util.List; 
/** 
 * Created by Roney on 2016/10/10. 
 * 楼层管理 
 * 
 */ 
@Entity 
@Table(indexes = {@Index(name = "idx_floor_user",columnList = "user_id")}) 
public class Floor extends BaseDomain implements Serializable { 
 
  @Id 
  @GenericGenerator(name = "PKUUID", strategy = "uuid2") 
  @GeneratedValue(generator = "PKUUID") 
  @Column(length = 36) 
  protected String id; 
 
  /** 
   * 发布用户ID 
   */ 
  @Column(length = 36,name = "user_id") 
  private String userId; 
 
  /** 
   * 楼层名称 
   */ 
  private String name; 
 
  /** 
   * 楼层的模板路径 
   */ 
  private String templateUrl; 
 
  /** 
   * 类型 
   * 1.管理端 
   * 2.供应商 
   */ 
  private Integer type; 
 
 
  /** 
   * 排序 
   */ 
  @Column(name = "show_index", nullable = false) 
  private Integer showIndex; 
 
  /** 
   * 是否禁用 
   * */ 
 
 
  @Column(nullable = false) 
  private Boolean isDisable=false; 
 
  @OneToMany(fetch = FetchType.LAZY,mappedBy = "floor") 
  private List<FloorContent> floorContents; 
 
  public List<FloorContent> getFloorContents() { 
    return floorContents; 
  } 
 
  public void setFloorContents(List<FloorContent> floorContents) { 
    this.floorContents = floorContents; 
  } 
 
  public String getId() { 
    return id; 
  } 
 
  public void setId(String id) { 
    this.id = id; 
  } 
 
  public String getUserId() { 
    return userId; 
  } 
 
  public void setUserId(String userId) { 
    this.userId = userId; 
  } 
 
  public String getName() { 
    return name; 
  } 
 
  public void setName(String name) { 
    this.name = name; 
  } 
 
  public String getTemplateUrl() { 
    return templateUrl; 
  } 
 
  public void setTemplateUrl(String templateUrl) { 
    this.templateUrl = templateUrl; 
  } 
 
  public Integer getShowIndex() { 
    return showIndex; 
  } 
 
  public void setShowIndex(Integer showIndex) { 
    this.showIndex = showIndex; 
  } 
 
  public Boolean getDisable() { 
    return isDisable; 
  } 
 
  public void setDisable(Boolean disable) { 
    isDisable = disable; 
  } 
 
  @Override 
  public boolean equals(Object o) { 
    if (this == o) return true; 
    if (o == null || getClass() != o.getClass()) return false; 
 
    Floor floor = (Floor) o; 
 
    return id != null ? id.equals(floor.id) : floor.id == null; 
 
  } 
 
  @Override 
  public int hashCode() { 
    return id != null ? id.hashCode() : 0; 
  } 
} 

FloorContent类:

package cms.model; 
 
import cms.model.base.BaseDomain; 
import org.hibernate.annotations.GenericGenerator; 
 
import javax.persistence.*; 
import java.io.Serializable; 
 
/** 
 * Created by Roney on 2016/10/10. 
 * 楼层的内容 
 */ 
 
@Entity 
@Table(indexes = {@Index(name = "idx_floor_content_user", columnList = "user_id")}) 
public class FloorContent extends BaseDomain implements Serializable { 
 
  @Id 
  @GenericGenerator(name = "PKUUID", strategy = "uuid2") 
  @GeneratedValue(generator = "PKUUID") 
  @Column(length = 36) 
  protected String id; 
 
  /** 
   * 发布用户ID 
   */ 
  @Column(length = 36, name = "user_id") 
  private String userId; 
 
  /** 
   * 內容名稱 
   */ 
  private String name; 
 
  /** 
   * 
   * 內容圖片 
   */ 
  @Column(length = 256) 
  private String contentImageUrl; 
 
  /** 
   * 類型 
   * 1.超鏈接 
   * 2.圖片檢索 
   */ 
  private Integer type; 
 
  /** 
   * 超鏈接url 
   */ 
  private String linkUrl; 
 
  /** 
   * 圖片檢索內容 
   */ 
  private String picSearchContent; 
 
  /** 
   * 排序 
   */ 
  @Column(name = "show_index", nullable = false) 
  private Integer showIndex; 
 
  /** 
   * 是否禁用 
   */ 
 
  @Column(nullable = false) 
  private Boolean isDisable = false; 
 
  @ManyToOne 
  @JoinColumn(name = "floor_id",foreignKey = @ForeignKey(name = "fk_floor_fc")) 
  private Floor floor; 
 
  public Floor getFloor() { 
    return floor; 
  } 
 
  public void setFloor(Floor floor) { 
    this.floor = floor; 
  } 
 
  public String getId() { 
    return id; 
  } 
 
  public void setId(String id) { 
    this.id = id; 
  } 
 
  public String getUserId() { 
    return userId; 
  } 
 
  public void setUserId(String userId) { 
    this.userId = userId; 
  } 
 
  public String getName() { 
    return name; 
  } 
 
  public void setName(String name) { 
    this.name = name; 
  } 
 
  public String getContentImageUrl() { 
    return contentImageUrl; 
  } 
 
  public void setContentImageUrl(String contentImageUrl) { 
    this.contentImageUrl = contentImageUrl; 
  } 
 
  public Integer getType() { 
    return type; 
  } 
 
  public void setType(Integer type) { 
    this.type = type; 
  } 
 
  public String getLinkUrl() { 
    return linkUrl; 
  } 
 
  public void setLinkUrl(String linkUrl) { 
    this.linkUrl = linkUrl; 
  } 
 
  public String getPicSearchContent() { 
    return picSearchContent; 
  } 
 
  public void setPicSearchContent(String picSearchContent) { 
    this.picSearchContent = picSearchContent; 
  } 
 
  public Integer getShowIndex() { 
    return showIndex; 
  } 
 
  public void setShowIndex(Integer showIndex) { 
    this.showIndex = showIndex; 
  } 
 
  public Boolean getDisable() { 
    return isDisable; 
  } 
 
  public void setDisable(Boolean disable) { 
    isDisable = disable; 
  } 
 
  @Override 
  public boolean equals(Object o) { 
    if (this == o) return true; 
    if (o == null || getClass() != o.getClass()) return false; 
 
    FloorContent that = (FloorContent) o; 
 
    return id != null ? id.equals(that.id) : that.id == null; 
 
  } 
 
  @Override 
  public int hashCode() { 
    return id != null ? id.hashCode() : 0; 
  } 
} 

实体类已经出来了,现在具体说说怎么利用JPA中findBy来实现关联查询:

package cms.model.repository; 
import cms.model.Floor; 
import cms.model.FloorContent; 
import org.springframework.data.domain.Page; 
import org.springframework.data.domain.Pageable; 
import org.springframework.data.jpa.repository.JpaRepository; 
/** 
 * Created by Roney on 2016/10/10. 
 * Created by Roney on 2016/10/10. 
 * 楼层内容管理dao类 
 */ 
public interface FloorContentRepos extends JpaRepository<FloorContent,String>{ 
  public Page<FloorContent> findByFloor_IdAndIsDeleteOrderByShowIndexAsc(String floorId,boolean b, Pageable pageable); 
} 

从例子中就可以看出JPA关联查询主要在“_”这个符号的使用,下面来给大家具体的介绍一下这个符号到底代表什么含义。

首先findBy是必须写的,表示使用JPA规则进行查询。

如果查询的是本张表中的内容,例如查询本张表中的name字段就可以这么写:findByName()。

如果查询的是楼层中的name字段就可以这么写:findByFloor_Name()。

如果是既要查询本张表中的name字段,也要查询楼层中的name字段,就可以这么写:findByFloor_NameAndName()。

从上面的案例就可以看出可以在findBy后面添加要关联的实体类,然后在实体类后面写上“_”,"_"符号后面是添加关联表的字段而不是本身表的字段,这点要记住。如何还想关联更多的表可以在后面添加:And+表名字+“_”+表中要查询的字段。或者只是想关联本身的查询字段可以在后面添加:And+查询的字段。

千万不要写错了,写错的话运行都运行不起来的。所以写的时候要多看看是否符合规则。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# spring  # boot  # jpa  # 关联  # 关联查询  # 查询  # SpringBoot Data JPA 关联表查询的方法  # Spring Data JPA 实现多表关联查询的示例代码  # SpringData JPA中@OneToMany和@ManyToOne的用法详解  # 详谈jpa中表的@OneToMany等关联关系  # 就可以  # 的是  # 给大家  # 实体类  # 在后面  # 介绍一下  # 也要  # 错了  # 千万不要  # 要多  # 还想  # 可以看出  # 两张  # 来实现  # 既要  # 中就  # 写上  # 中要  # 源代码  # 大家多多 


相关文章: 定制建站流程步骤详解:一站式方案设计与开发指南  网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?  如何获取开源自助建站系统免费下载链接?  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  建站主机功能解析:服务器选择与快速搭建指南  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  如何零基础开发自助建站系统?完整教程解析  如何确认建站备案号应放置的具体位置?  宁波自助建站系统如何快速打造专业企业网站?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  宝塔建站后网页无法访问如何解决?  小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化  浅析上传头像示例及其注意事项  c# 在高并发下使用反射发射(Reflection.Emit)的性能  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  代刷网站制作软件,别人代刷火车票靠谱吗?  整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?  网站网页制作专业公司,怎样制作自己的网页?  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  如何在香港服务器上快速搭建免备案网站?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  建站主机如何选?性能与价格怎样平衡?  在线教育网站制作平台,山西立德教育官网?  如何确保西部建站助手FTP传输的安全性?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  如何在云服务器上快速搭建个人网站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  已有域名如何快速搭建专属网站?  如何快速搭建支持数据库操作的智能建站平台?  Swift中循环语句中的转移语句 break 和 continue  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  如何在阿里云部署织梦网站?  建站之星后台管理如何实现高效配置?  如何撰写建站申请书?关键要点有哪些?  学校建站服务器如何选型才能满足性能需求?  Bpmn 2.0的XML文件怎么画流程图  如何快速使用云服务器搭建个人网站?  建站之星图片链接生成指南:自助建站与智能设计教程  常州企业建站如何选择最佳模板?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何在腾讯云免费申请建站?  如何快速搭建个人网站并优化SEO?  宝塔面板创建网站无法访问?如何快速排查修复?  如何在企业微信快速生成手机电脑官网?  如何在阿里云通过域名搭建网站?  建站之星导航配置指南:自助建站与SEO优化全解析  如何通过虚拟机搭建网站?详细步骤解析  高防服务器租用如何选择配置与防御等级? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。