JPA 多表分页查询
业务场景:大学生毕业后统计毕业去向。学生实体和毕业去向实体一对一关系。
实体:
@Entity
@Data
@Table(name = "t_s_student")
public class TSStudent implements Serializable { /**主键*/
@Id
@GeneratedValue(generator = "idGenerator")
@GenericGenerator(name = "idGenerator",strategy = "uuid")
@Column(length = 32)
private String id; /**姓名*/
@Column(name = "name")
private String name; /**学号*/
@Column(name = "student_id",length = 20)
private String studentId; /**电话*/
@Column(name = "phone",length = 20)
private String phone; /**地址*/
@Column(name = "address",length = 200)
private String address; /**籍贯*/
@Column(name = "birthplace",length = 200)
private String birthplace;
/**生日*/ @Column(name = "birthday")
private String birthday; /**毕业时间*/
@Column(name = "graduation_time")
private String graduationTime; /**班级*/
@Column(name = "clazz",length = 50)
private String clazz; /**
* 性别
*/
@Column(name = "sex",length = 5)
private String sex; /**
* 年级
*/
@Column(name = "grade",length = 20)
private String grade;
/**
* 成绩
*/
@Column(name = "achievement",length = 20)
private String achievement; /**
* 毕业去向
*/
@Column(name = "graduation",length = 100)
private String graduation; /**
* 所在地区
*/
@Column(name = "area",length = 200)
private String area; /**
*/
@Column(name = "qq",length = 20)
private String qq; /**
* 行业
*/
@Column(name = "industry",length = 20)
private String industry; }
毕业去向实体:
@Entity
@Table(name ="t_s_graduation")
@Data
public class TSGraduation implements Serializable { @Id
@GeneratedValue(generator = "idGenerator")
@GenericGenerator(name = "idGenerator",strategy = "uuid")
@Column(length = 32)
private String id; /**
* 城市
*/
@Column(name = "city",length = 50)
private String city; /**
* 公司名
*/
@Column(name = "company",length = 100)
private String company; /**
* 公司地址
*/
@Column(name = "company_address",length = 200)
private String companyAddress; /**
* 公司电话
*/
@Column(name = "company_phone",length = 20)
private String companyPhone; /**
* 从事行业
*/
@Column(name = "industry",length = 20)
private String industry; /**
* 所属地区
*/
@Column(name = "area",length = 100)
private String area; /**
* 入职时间
*/
@Column(name = "entry_time",length = 20)
private String entryTime; /**
* 薪资
*/
@Column(name = "salary")
private Integer salary; /**
* 是否有五险一金
*/
@Column(name = "has_insurance_and_housing_fund",length = 5)
private String hasInsuranceAndHousingFund; /**
* 关联学生ID
*/
@OneToOne(cascade = CascadeType.ALL)//student 是关系的维护端,当删除学生的时候,会级联删除去向信息
@JoinColumn(name = "student_id",referencedColumnName = "id")//去向中的student_id字段参考学生表中的ID字段
private TSStudent student;
}
分页服务接口实现:
@Override
public Page<TSGraduation> search(TSGraduation graduation, AbstractPageRequest pageable) {
return graduationRepository.findAll(new Specification<TSGraduation>() {
@Override
public Predicate toPredicate(Root<TSGraduation> root, CriteriaQuery<?> query, CriteriaBuilder criteriaBuilder) { List<Predicate> list = new ArrayList<>(); //获取学生属性,查询条件
Join<Object, TSStudent> student = root.join("student", JoinType.LEFT); if (graduation.getStudent() != null && !StringUtils.isEmpty(graduation.getStudent().getClazz())){
list.add(criteriaBuilder.like(student.get("clazz").as(String.class),"%" + graduation.getStudent().getClazz() + "%"));
}
if (graduation.getStudent() != null && !StringUtils.isEmpty(graduation.getStudent().getName())){
list.add(criteriaBuilder.like(student.get("name").as(String.class),"%" + graduation.getStudent().getName() + "%"));
} if (graduation.getStudent() != null && !StringUtils.isEmpty(graduation.getStudent().getSex())){
list.add(criteriaBuilder.equal(student.get("sex").as(String.class),graduation.getStudent().getSex()));
} if (graduation.getStudent() != null && !StringUtils.isEmpty(graduation.getStudent().getGraduation())){
list.add(criteriaBuilder.equal(student.get("graduation").as(String.class), graduation.getStudent().getGraduation() ));
} if (!StringUtils.isEmpty(graduation.getCompany())){
list.add(criteriaBuilder.like(root.get("company"),"%" + graduation.getCompany()+ "%"));
} if (!StringUtils.isEmpty(graduation.getIndustry())){
list.add(criteriaBuilder.like(root.get("industry"),"%" + graduation.getIndustry()+ "%"));
} if (!StringUtils.isEmpty(graduation.getArea())){
list.add(criteriaBuilder.like(root.get("area"),"%" + graduation.getArea()+ "%"));
} if (!StringUtils.isEmpty(graduation.getSalary())){
list.add(criteriaBuilder.equal(root.get("salary"),graduation.getSalary()));
} if (!StringUtils.isEmpty(graduation.getHasInsuranceAndHousingFund())){
list.add(criteriaBuilder.equal(root.get("hasInsuranceAndHousingFund"),graduation.getHasInsuranceAndHousingFund()));
} return criteriaBuilder.and(list.toArray(new Predicate[list.size()]));
}
},pageable);
}
参考:https://blog.csdn.net/qq_36289377/article/details/80761103
JPA 多表分页查询的更多相关文章
- JdbcTemplate+PageImpl实现多表分页查询
一.基础实体 @MappedSuperclass public abstract class AbsIdEntity implements Serializable { private static ...
- sql连表分页查询(存储过程)
1.平时分页查询都比较多针对一个表的数据 而这个分页查询是针对连表查询的 ,这也是我网上改版别人的sql语句 先在数据库新建一个存储过程 拷贝以下代码 CREATE PROCEDURE [dbo].[ ...
- Mybatis-plus多表关联查询,多表分页查询
学习plus真的觉得写代码真的越来越舒服了.昨天开始接触吧,只要学会了多表关联查询.plus就能随意搭配使用了. 关于怎么搭建的就自行了去研究了哦.这里直接进入主题. 我用的是springboot+m ...
- spring jpa 带参数分页查询(一)
1.写个接口继承JpaRepository @NoRepositoryBean public interface BaseRepository<T,PK extends Serializable ...
- springBootJpa 联表分页查询总数不准的问题
问题情景: 在联表查询时 ``` // 两张表关联查询 Join<Project, Plan> planJoin = root.join("plans", JoinTy ...
- SQLServer多表联查,多表分页查询
多表联查: select p.*,s.Sheng , i.Shifrom [dbo].[ProductRecordInfo] --表名 p left join [ShengInfo] s on ...
- jpa自定义条件分页查询
主要依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>sp ...
- .net EF Join 关联表分页查询
Join中第二个参数和第三个参数即为两张表关联对应的字段 第四个参数new 后面如果不写Model名,系统会自动生成带字段的list类型 IQueryable<Operator> oper ...
- jpa多表leftjoin 查询,自定义返回结果
sql代码 自定义返回结果 package com.cdp.ecosaas.coredb.uua.sync.vo; import java.io.Serializable; public class ...
随机推荐
- 双人对战的球类游戏ios源代码项目
双人对战的球类游戏源代码,这个是一款双人对战的ios球类游戏源代码.游戏的源代码也比較具体的,我们在屏幕上下看到各有一个球门.内有一球,两边通过控制轮盘使球进入对方的球门的.事实上玩法也非常easy的 ...
- Oracle基础 索引
一.索引 索引是一种快速访问数据的途径,可提高数据库性能.索引使数据库程序无须对整个表进行扫描,就可以在其中找到所需的数据,就像书的目录,可以快速查找所需的信息,无须阅读整本书. (一)索引的分类 逻 ...
- Python3链接MySQL数据库
Python 2.x 上连接MySQL的库倒是不少的,其中比较著名就是MySQLdb(Django项目都使用它:我也在开发测试系统时也使用过),见:http://sourceforge.net/pro ...
- Codeforces 463C Gargari and Bishops 题解
题目出处: http://codeforces.com/contest/463/problem/C 感觉本题还是挺难的.须要好好总结一下. 计算对角线的公式: 1 右斜对角线,也叫主对角线的下标计算公 ...
- 【BIEE】分析的解析机制
今天使用BIEE时意外的发现个问题,BIEE在展示结果时候,是先进行排序,然后再展示.具体测试案例如下: 首先,存在如下数据: 在BIEE展示效果如下: 目前是根据O1,02,03,04,05,06, ...
- mybatis 遇到的问题
顺序问题:在resultmap中,result必须在association之前.否则会报错 只查出一条记录的问题 :重名的id,要起别名.而且不能忽略. mybaits错误解决:There is n ...
- 走进windows编程的世界-----消息处理函数(3)
二 定时器消息 1 定时器消息 WM_TIMER 依照定时器设置时间段,自己主动向窗体发送一个定时器消息WM_TIMER. 优先级比較低. 定时器精度比較低,毫秒级别.消息产生时间也精度比較低 ...
- ApplicationMaster是如何启动container并通信
ApplicationMaster是如何启动container并通信 hadoop的关键进程 http://blog.csdn.net/jediael_lu/article/details/46386 ...
- Log4J 基本使用
Log4j由三个重要的组件 构 成:日志 信息 的优先级,日志信息的输出目的地,日志信息的输出格式. 日志信息的优先级 从高到低有ERROR . WARN . INFO . DEBUG ,分别用来指定 ...
- 使用MongoDB 记录业务日志
最近公司有个需求,要对业务日志进行记录并根据日志排查问题,以前都是使用log4net之类的日志组件来记录到文件,这种方式已经不能满足业务的需要,因为日志文件会很大,即使进行分割后,查找也是很不方便,何 ...