今天给大家介绍一下如何利用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小时内与您取得联系。