实体类

  @Entity

  @Table(name = "t_hotel")

  @Data

  public class THotel {

  @Id

  private int id;

  private String name;

  private String address;

  /**

  * 城市id

  */

  private String city;

  }

  @Entity

  @Table(name = "t_city")

  @Data

  public class TCity {

  @Id

  private int id;

  private String name;

  private String state;

  private String country;

  private String map;

  }

  在启动SpringBoot的时候 SpringDataJpa会自动的在数据库中生成表结构.

  为了查询要求,我随便的增加了一些数据,如下图所示

  

  新建接口

  public interface TCityRepository extends JpaRepository, JpaSpecificationExecutor {

  }

  单元测试类

  @RunWith(SpringRunner.class)

  @SpringBootTest

  public class TCityRepositoryTest{

  @Autowired

  private TCityRepository tCityRepository;

  }

  1.查找出Id小于3,并且名称带有shanghai的记录.

  /**

  * 查找出Id小于3,并且名称带有`shanghai`的记录.

  *

  * @param id id

  * @param name 城市名称

  * @return 城市列表

  */

  List findByIdLessThanAndNameLike(int id, String name);

  单元测试

  @Test

  public void findByIdLessThanAndNameLike() throws Exception {

  List shanghai = tCityRepository.findByIdLessThanAndNameLike(3, "%shanghai%");

  Assert.assertTrue(shanghai.size() > 0);

  }

  2.通过旅店名称分页查询旅店以及城市的所有信息

  /**

  * 通过旅店名称分页查询旅店以及城市的信息

  *

  * @param name 旅店名称

  * @param pageable 分页信息

  * @return Page

  */

  @Query(value = "select t1.name as cityName,t2.name as hotelName\n" +

  "from t_city t1\n" +

  " left join t_hotel t2 on t2.city = t1.id\n" +

  "where t2.name = :name",

  countQuery = "select count(*)" +

  "from t_city t1 \n" +

  " left join t_hotel t2 on t2.city = t1.id\n" +

  "where t2.name = :name"

  , nativeQuery = true)

  Page findCityAndHotel(@Param("name") String name, Pageable pageable);

  为了节约时间 我只在select 与 from 之间 分别查询了城市的名称以及旅店的名称如果要查所有的信息,可以换成

  t1.* ,

  t2.*

  单元测试

  @Test

  public void findCityAndHotel() throws Exception {

  Page cityAndHotel = tCityRepository.findCityAndHotel("酒店", new PageRequest(0, 10));

  Assert.assertTrue(cityAndHotel.getTotalElements() > 0);

  }

  关于把List 转换成List<对象> 的方法 我已经在上一篇JPA的文章中比较清楚的说了,因此我就不再重复的叙述一遍了

  3.HQL通过旅店名称查询旅店以及城市的所有信息

  3和2其实是一样的,为了方便我就不作出分页查询了

  HQL可以用map来接受返回的参数,具体的用法如下所示:

  /**

  * HQL通过旅店名称查询旅店以及城市的所有信息

  *

  * @return

  */

  @Query(value = "select new map(t1,t2) from TCity t1 left join THotel t2 on t1.id=t2.city where t2.name =:name")

  List> findCityAndHotelByHQL(@Param("name") String name);

  测试方法和2是差不多的 我就不粘贴了

  Map 转换实体类的方法也挺多的我就不多说了,如果是直接返回给前台的话,也没有必要转换成对象.

  4.HQL通过旅店名称查询旅店以及城市的所有信息 直接返回实体类

  /**

  * 关联查询

  *

  * @return

  */

  @Query(value = "select new pers.zpw.domain.CityHohel(t1.name AS cityName,t2.name AS hotelName) from TCity t1 left join THotel t2 on t1.id=t2.city where t2.name =:name")

  List findCityAndHotelByHQLResultObj(@Param("name") String name);

  为了方便CityHohel我只封装了2个属性,这和HQL查询的字段是完全一致的,也必须要保持一致.

  /**

  * Created by ZhuPengWei on 2018/5/12.

  */

  @Data

  public class CityHohel {

  private String cityName;

  private String hotelName;

  public CityHohel(String cityName, String hotelName) {

  this.cityName = cityName;

  this.hotelName = hotelName;

  }

  }

  当然这个带参的构造方法是必须要写的,否则会抛出转换实体的异常

  单元测试

  @Test 无锡人流医院 http://www.wxbhnk120.com/

  public void findCityAndHotelByHQLResultObj() throws Exception {

  List cityAndHotelByHQLResultObj = tCityRepository.findCityAndHotelByHQLResultObj("酒店");

  Assert.assertTrue(cityAndHotelByHQLResultObj.size() > 0);

  }

  4.HQL通过旅店名称分页查询旅店以及城市的所有信息 直接返回实体类

  /**

  * 关联查询

  *

  * @return

  */

  @Query(value = "select new pers.zpw.domain.CityHohel(t1.name AS cityName,t2.name AS hotelName) from TCity t1 left join THotel t2 on t1.id=t2.city where t2.name =:name",

  countQuery = "select count(*) from TCity t1 left join THotel t2 on t1.id=t2.city where t2.name =:name")

  Page findCityAndHotelAllSelf(@Param("name") String name, Pageable pageable);

  @Test

  public void findCityAndHotelAllSelf() throws Exception {

  Page cityAndHotelAllSelf = tCityRepository.findCityAndHotelAllSelf("酒店", new PageRequest(0, 10));

  Assert.assertTrue(cityAndHotelAllSelf.getTotalElements() > 0);

  }

  5.动态查询旅店以及城市的所有信息 直接返回实体类

  如果是动态查询的话当然首先得构造一条sql去查询了,当然如果不是自定义实体对象的话这样的网上一大堆我就不写了.

  直接走测试

  @Autowired

  @PersistenceContext

  private EntityManager entityManager;

  @Test

  public void testDynamic() throws Exception {

  String sql = "select new pers.zpw.domain.CityHohel(t1.name AS cityName,t2.name AS hotelName) from TCity t1 left join THotel t2 on t1.id=t2.city where t2.name ='酒店'";

  Query query = entityManager.createQuery(sql);

  List resultList = query.getResultList();

  Assert.assertTrue(resultList.size() > 0);

  }

  这样测试是通过的,因此可以知道在业务层的方法中我们可以动态的构造SQL语句. 比如说可以在接口中这样子来定义一个方法

  /**

  * 自定义查询

  * @param sql

  * @param entityManager

  * @return

  */

  default List customQuery(String sql, EntityManager entityManager) {

  return entityManager.createQuery(sql).getResultList();

  }

  然后在测试类中动态的根据条件去拼接SQL语句去调用

Spring Data Jpa 复杂查询总结的更多相关文章

  1. spring data jpa 分页查询

    https://www.cnblogs.com/hdwang/p/7843405.html spring data jpa 分页查询   法一(本地sql查询,注意表名啥的都用数据库中的名称,适用于特 ...

  2. spring data JPA entityManager查询 并将查询到的值转为实体对象

    spring data JPA entityManager查询 并将查询到的值转为实体对象 . https://blog.csdn.net/qq_34791233/article/details/81 ...

  3. 【Spring Data 系列学习】Spring Data JPA 基础查询

    [Spring Data 系列学习]Spring Data JPA 基础查询 前面的章节简单讲解了 了解 Spring Data JPA . Jpa 和 Hibernate,本章节开始通过案例上手 S ...

  4. Spring Boot 入门系列(二十七)使用Spring Data JPA 自定义查询如此简单,完全不需要写SQL!

    前面讲了Spring Boot 整合Spring Boot JPA,实现JPA 的增.删.改.查的功能.JPA使用非常简单,只需继承JpaRepository ,无需任何数据访问层和sql语句即可实现 ...

  5. Spring Data JPA 简单查询--接口方法

    一.接口方法整理速查 下表针对于简单查询,即JpaRepository接口(继承了CrudRepository接口.PagingAndSortingRepository接口)中的可访问方法进行整理.( ...

  6. Spring Data JPA 实例查询

    一.相关接口方法     在继承JpaRepository接口后,自动拥有了按"实例"进行查询的诸多方法.这些方法主要在两个接口中定义,一是QueryByExampleExecut ...

  7. springboot整合spring data jpa 动态查询

    Spring Data JPA虽然大大的简化了持久层的开发,但是在实际开发中,很多地方都需要高级动态查询,在实现动态查询时我们需要用到Criteria API,主要是以下三个: 1.Criteria ...

  8. springboot集成Spring Data JPA数据查询

    1.JPA介绍 JPA(Java Persistence API)是Sun官方提出的Java持久化规范.它为Java开发人员提供了一种对象/关联映射工具来管理Java应用中的关系数据.它的出现主要是为 ...

  9. Spring Data JPA 条件查询的关键字

    Spring Data JPA 为此提供了一些表达条件查询的关键字,大致如下: And --- 等价于 SQL 中的 and 关键字,比如 findByUsernameAndPassword(Stri ...

  10. Spring Data JPA简单查询接口方法速查

    下表针对于简单查询,即JpaRepository接口(继承了CrudRepository接口.PagingAndSortingRepository接口)中的可访问方法进行整理.(1)先按照功能进行分类 ...

随机推荐

  1. Data truncation: Out of range value for column 'quanity' at row 问题解决方案

    由于之前在自己电脑上搭建了mysql 5.6的数据库,但是在服务器上搭建的是mysql 5.7的环境,在运行过程中出现了如下错误: Data truncation: Out of range valu ...

  2. Python统计数据库中的数据量【含MySQL、Oracle】

    Python程序文件如下: # -*- coding: utf-8 # File : start.py # Author : baoshan import json import pymysql im ...

  3. Python3基础 内置函数 eval str转为list tuple dict

             Python : 3.7.3          OS : Ubuntu 18.04.2 LTS         IDE : pycharm-community-2019.1.3    ...

  4. Python 处理异常栈模块——traceback 模块

    异常捕捉 通常我们在项目中,针对异常的捕捉会使用 try + except,基本形式如下: try: # 主代码 except IndexError as e: # 索引异常时执行这里 logger. ...

  5. k8s记录-Dockerfile详解

    Dockerfile命令详解 下面我们来分别介绍下上面使用到的命令: FROM 格式:FROM 或FROM :. 解释:FROM必须是Dockerfile里的第一条指令(注视除外),后面跟有效的镜像名 ...

  6. Mouse Genome Informatics(MGI)数据库介绍

    欢迎来到"bio生物信息"的世界 有些人研究了很久的基因,都不一定知道他们研究的基因在小鼠模型上发挥什么作用--陈文燕 今天想介绍一个数据库MGI,全称Mouse Genome I ...

  7. eclipse 中的注释 快捷键 多行注释快捷键 单行注释快捷键

    本文链接:https://blog.csdn.net/a0701302/article/details/76177244 Eclipse 中的两种注释方法: (1)多行注释 (2)单行注释 一. 多行 ...

  8. 问题解决: 此文件来自其他计算机,可能被阻止以帮助保护该计算机/WORD在试图打开文件时遇到错误……

    最近,在打开下载的office文档(包括word.excel.ppt等)时候,总是无法直接打开,错误提示如下: 无论是邮件中的还是别的网站下载的,均提示该错误.后来搜索相关资料发现,修改其文件属性即可 ...

  9. shell中 >/dev/null 2>&1是什么意思

    原文地址:http://juke.outofmemory.cn/entry/295292 我们经常能在 shell 脚本中发现 >/dev/null 2>&1 这样的语句.以前的我 ...

  10. Android组件化aar躺坑记:ButterKnife 报 元素值必须为常量表达式错误

    背景: 项目有需求,将自己写的模块作为一个module给到大项目使用,所以准备把自己的项目打包成aar包. 一.如何将独立项目打包成aar: 1.修改module下的application 为libr ...