随便说说Spring Data JPA(包含分页,复合查询)

  最近没事做,闲着也是闲着,随便写写,自己说说,不提供参考价值。

  Spring Data JPA是Spring Data家族的一部分,可以轻松实现基于JPA的存储库。 此模块处理对基于JPA的数据访问层的增强支持。 它使构建使用数据访问技术的Spring驱动应用程序变得更加容易。

  在相当长的一段时间内,实现应用程序的数据访问层一直很麻烦。 必须编写太多样板代码来执行简单查询以及执行分页和审计。 Spring Data JPA旨在通过减少实际需要的工作量来显著改善数据访问层的实现。 作为开发人员,您编写repository接口,包括自定义查找器方法,Spring将自动提供实现。例如,你继承JpaRepository<实体类,主键类型>,他会提供很方便的查询方法,运用findby+字段,完全不需要开发人员写sql就可以查询你需要的。至于findby的用法可以百度,可以拼接很多关键字来扩展。这个是一般情况,但是实际中可能用的地方就不会这么简单了,我们来具体说说或者说举例来说明吧。

  一般:就像上面说的,优秀。

  分页:分页其实说白了就是2个查询。我们通过使用标签@query内含原生态nativeQuery=ture来手动编写,列表sql运用value,数量sql用countQuery,返回page属性。但是注意@query的时候有讲究,当遇到不同数据库的后面需要拼接的东西不一样。比如orcale是?#{#pageable},mysql是 \n#pageable\n ,sqlsever是 \n-- #pageable\n 。

     例:@Query(value="select * from C_Article where type=:type \n--#pageable\n",countQuery="select count(*) from C_Article where type=:type",nativeQuery=true)

        Page<C_Article> findByType(@Param("type") String type,Pageable pageable);

    所以总结来说还是比较蛋疼,而且还没说其他复合情况。

  复合查询:一般的复合我们可以用原生态的sql解决,即nativeQuery=ture。当遇到条件拼接查询的时候我第一次就傻掉了。查了好久,没找到感觉舒适的。他需要我们实现JpaRepository<实体类,主键类型>和JpaSpecificationExecutor<实体类>,实体类还得写个原型类。service实现类里面的方法通过findAll((root, criteriaQuery, criteriaBuilder)来构造sql。

    例:实体类

@Entity
@Data/**这个是lombok标签**/
@Table(name="news")
public class News implements Serializable{
  @Id
  private String Id;

  private String Type;

  private String Title;

  private String Creater;
}

  模型类

@Generated(value = "org.hibernate.jpamodelgen.JPAMetaModelEntityProcessor")
@StaticMetamodel(News.class)
public class News_ {
  public static volatile SingularAttribute<News, String> Id;
  public static volatile SingularAttribute<News, String> Type;
  public static volatile SingularAttribute<News, String> Title;
  public static volatile SingularAttribute<News, String> Creater;
}

  service类就不传了。看下serviceImp这个里面的方法,这个是蛋疼的地方

public List<News> newsList(String type, String creater) {
	return (这个是你注入的repository)repository.findAll((root, criteriaQuery, criteriaBuilder) -> {
            List<Predicate> predicatesList = new ArrayList<>();
            if (creater!="" ) {
                predicatesList.add(
                        criteriaBuilder.and(
                                criteriaBuilder.like(
                                        root.get(News_.Creater), "%" + creater+ "%")));
            }
            if (type!="") {
                predicatesList.add(
                        criteriaBuilder.and(
                                criteriaBuilder.like(
                                        root.get(News_.Type), "%"+type+"%")));
            }
            return criteriaBuilder.and(
                    predicatesList.toArray(new Predicate[predicatesList.size()]));
        });
	}

    DAO类

public interface NewsRepository extends JpaRepository<News, String>,JpaSpecificationExecutor<News>{
  List<News> newsList(String type,String create)
}

  criteriaBuilder这个包含不止like,还有其他的我就不一一列举了,具体还有啥建议点进去看源码。但是这样一看是不是很麻烦。所以实际运用上还是不建议使用。

  总结一句话,还是老老实实用mybatis就好了,mybatis-plus搭配起来就可以写的很舒畅了。

 

  

原文地址:https://www.cnblogs.com/lannoy/p/11888133.html

时间: 2024-10-04 12:16:10

随便说说Spring Data JPA(包含分页,复合查询)的相关文章

Spring Data Jpa 实现分页(Spring MVC+easyui)

spring data jpa很好的对dao层进行了封装,这篇文章主要来写的是实现easyui datagird数据分页,由于各个UI参数不大一样,所以如果使用的是其他UI,得稍作修改.需要说明的是我的代码是在spring mvc框架下的部分代码,部分结构的代码为给出,只给出关键代码. 首先,easy ui向服务端发送请求时,会自动返回4个参数(page,rows,order,sort),先写一个PageContent类: package module.system.entity; import

Spring data jpa 实现简单动态查询的通用Specification方法

本篇前提: SpringBoot中使用Spring Data Jpa 实现简单的动态查询的两种方法 这篇文章中的第二种方法 实现Specification 这块的方法 只适用于一个对象针对某一个固定字段查询,下面通过泛型改写了这个方法: import java.util.List; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import j

Spring Data Jpa (四)注解式查询方法

详细讲解声明式的查询方法 1 @Query详解 使用命名查询为实体声明查询是一种有效的方法,对于少量查询很有效.一般只需要关心@Query里面的value和nativeQuery的值.使用声明式JPQL查询有一个好处,就是启动的时候就知道语法正确与否. 声明一个注解在Repository的查询方法上. Like查询,注意firstname不会自动加上%关键字的 直接用原始SQL. nativeQuery不支持直接Sort的参数查询 错误方式: 正确方式: [email protected]排序

Spring Data JPA 的 Specifications动态查询

主要的结构: 有时我们在查询某个实体的时候,给定的条件是不固定的,这时就需要动态构建相应的查询语句,在Spring Data JPA中可以通过JpaSpecificationExecutor接口查询.相比JPQL,其优势是类型安全,更加的面向对象. import java.util.List; import org.springframework.data.domain.Page; import org.springframework.data.domain.Pageable; import o

模糊查询:Spring Data JPA 如何进行模糊查询(LIKE) ?

原文详见----->  https://blog.csdn.net/czx1204/article/details/79131281 一. 方法一 1.  Controller层: 方法参数如下,一定要加 "%"+name+"%" /** * @description: * @author: 程志祥<[email protected]com> * @date: 2018/1/22 下午5:15 * @version: V1.0 */ @RestCo

使用Spring Data JPA进行数据分页与排序

一.导读 如果一次性加载成千上万的列表数据,在网页上显示将十分的耗时,用户体验不好.所以处理较大数据查询结果展现的时候,分页查询是必不可少的.分页查询必然伴随着一定的排序规则,否则分页数据的状态很难控制,导致用户可能在不同的页看到同一条数据.那么,本文的主要内容就是给大家介绍一下,如何使用Spring Data JPA进行分页与排序. 二.实体定义 我们使用一个简单的实体定义:Article(文章) @Data @AllArgsConstructor @NoArgsConstructor @Bu

整合Spring Data JPA与Spring MVC: 分页和排序

之前我们学习了如何使用Jpa访问关系型数据库.比较完整Spring MVC和JPA教程请见Spring Data JPA实战入门,Spring MVC实战入门. 通过Jpa大大简化了我们对数据库的开发工作.但是,之前的例子中我们只提到了最简单的CRUD(增删改查)操作.实际上,Spring Data Jpa对于分页以及排序的查询也有着完美的支持,接下来,我们来学习如何通过Pageable来对数据库进行分页查询. 添加maven依赖 首先我们需要引入Jpa,数据库直接使用hsqldb内存数据库就可

深入浅出学Spring Data JPA

第一章:Spring Data JPA入门   Spring Data是什么 Spring Data是一个用于简化数据库访问,并支持云服务的开源框架.其主要目标是使得对数据的访问变得方便快捷,并支持map-reduce框架和云计算数据服务. Spring Data 包含多个子项目: Commons - 提供共享的基础框架,适合各个子项目使用,支持跨数据库持久化 JPA - 简化创建 JPA 数据访问层和跨存储的持久层功能 Hadoop - 基于 Spring 的 Hadoop 作业配置和一个 P

深入浅出学Spring Data JPA toPredicate Predicate[] p = new Predicate[list.size()]; query.where(cb.and

序言自工作以来,除了以前比较流量的hibernate,就是一直使用ORM 规范 JPA了.而这几天工作需要,研究了下JPA的标准查询,名为:JPA criteria查询.相比JPQL,其优势是类型安全,更加的面向对象.使用标准查询,开发人员可在编译的时候就检查查询的正确与否.而以前也只是在Hibernate中听说有过.具体不详,没用过.JPA元模型概念,及使用在JPA中,标准查询是以元模型的概念为基础的.元模型是为具体持久化单元的受管实体定义的.这些实体可以是实体类,嵌入类或者映射的父类.提供受