Spring Data 项目的目的是为了简化构建基于 Spring 框架应用的数据访问计数,包括非关系数据库、Map-Reduce 框架、云数据服务等等,SpringData JPA是简化创建 JPA 数据访问层和跨存储的持久层功能,通过一个接口的继承即可实现简单的CRUD。

  数据库的连接与项目的构建不说了,可以参考:springboot实战SpringDataJPA。我采用的是eclipse构建的普通的springboot项目。

一、创建表与实体类映射

@Entity
@Table(name = "student")
public class Student implements Serializable {
@Id
// id自动生成
@GeneratedValue
@Column(name = "id")
private Long id;
@Column(name = "name")
private String name;
@Column(name = "clas")
private String clas; @Column(name = "interest")
private String interest; // 省略了getter(),setter()方法 

二、创建StudentMapper 继承JpaRepository<Student, Long>,第一个参数是实体,第二个参数是主键的类型

public interface StudentMapper extends JpaRepository<Student, Long> {
// int queryCount();
// 自定义的方法实现findAll
@Query(value = "select * from student where id < ?1", nativeQuery = true)
public List<Student> findAll(Long id);
}

三、Controller内的代码如下:

@Resource
private FirstPageService firstPageService; @RequestMapping(value = "/", method = RequestMethod.GET)
@Fooish(tags = { "this_is_method" })
String home() {
return firstPageService.getString();
} @RequestMapping(value = "/add", method = RequestMethod.GET)
String addStudent(Student student) {
return firstPageService.addStudent(student);
} @RequestMapping(value = "/delete", method = RequestMethod.GET)
String deleteStudent(Long id) {
return firstPageService.deleteStudent(id);
} @RequestMapping(value = "/update", method = RequestMethod.GET)
String updateStudent(Student student) {
return firstPageService.updateStudent(student);
} @RequestMapping(value = "/list", method = RequestMethod.GET)
List<Student> listStudent() {
return firstPageService.listStudent();
} // 采用的是自定义的方法
@RequestMapping(value = "/list2", method = RequestMethod.GET)
List<Student> list2Student(Long id) {
return firstPageService.nativeQuery(id);
} // 分页查询
@RequestMapping(value = "/pageRequest", method = RequestMethod.GET)
List<Student> pageRequest() { return firstPageService.pageRequest();
} // 分页与排序查询
@RequestMapping(value = "/pageAndSortRequest", method = RequestMethod.GET)
List<Student> pageAndSortRequest() { return firstPageService.pageAndSortRequest();
}

四、服务层firstPageService代码如下:

@Resource
private StudentMapper studentMapper; public String getString() { // return name;
// int a = studentMapper.queryCount();
// return a + "";
return "Hellow World!";
} public String addStudent(Student stu) {
studentMapper.save(stu);
return "添加成功";
} public String deleteStudent(Long id) {
studentMapper.delete(id);
return "删除成功";
} public String updateStudent(Student stu) {
// 如果有就更新,没有就添加
studentMapper.save(stu);
return "更新成功";
} public List<Student> listStudent() { return studentMapper.findAll();
} public List<Student> nativeQuery(Long id) {
return studentMapper.findAll(id);
}

    // 分页查询
public List<Student> pageRequest() {
PageRequest pageRequest = new PageRequest(1, 3);
Page<Student> stuPage = studentMapper.findAll(pageRequest);
List<Student> stuList = stuPage.getContent();
return stuList;
}

    // 分页与排序
public List<Student> pageAndSortRequest() {
Sort sort1 = new Sort(Sort.Direction.DESC, "id");
Sort sort2 = new Sort(Sort.Direction.ASC, "name");
// 把两个排序的条件取取与
Sort sort = sort1.and(sort2);
PageRequest pageRequest = new PageRequest(1, 2, sort);
Page<Student> stuPage = studentMapper.findAll(pageRequest);
List<Student> stuList = stuPage.getContent();
return stuList;
}

  

通过源码的继承与实现关系可以看出,JpaRepository接口继承了PagingAndSortingRepository,QueryByExampleExecutor两个接口,PagingAndSortingRepository接口继承了CrudRepository。CrudRepository中包含了简单的数据库增,删,改,查,这四个操作还是比较简单的,下面主要介绍分页与排序;

下面的是PagingAndSortingRepository的源码:

public interface PagingAndSortingRepository extends CrudRepository {

	public abstract Iterable findAll(Sort sort);

	public abstract Page findAll(Pageable pageable);
}

这个接口提供了分页与排序的基本方法,想要实现分页查询,要实现Pageable接口,而PageRequest是该接口的一个实现类,该类的构造方法:

    // 单纯的分页
    public PageRequest(int page, int size) {
this(page, size, null);
} public transient PageRequest(int page, int size, Sort.Direction direction,
String properties[]) {
this(page, size, new Sort(direction, properties));
}
      // 分页与排序,要实现Sort类
public PageRequest(int page, int size, Sort sort) {
super(page, size);
this.sort = sort;
}

 

五、按照id倒序,name顺序,查询第二页,每页显示两个的查询结果:

SpringData JPA实现CRUD,分页与多参数排序的更多相关文章

  1. SpringData JPA快速入门和基本的CRUD操作以及Specifications条件查询

    SpringData JPA概述: SpringData JPA 是 Spring 基于 ORM 框架.JPA 规范的基础上封装的一套JPA应用框架,可使开发者用极简的代码即可实现对数据库的访问和操作 ...

  2. Spring Boot CRUD+分页(基于JPA规范)

    步骤一:JPA概念 JPA(Java Persistence API)是Sun官方提出的Java持久化规范,用来方便大家操作数据库. 真正干活的可能是Hibernate,TopLink等等实现了JPA ...

  3. springdata jpa 关于分页@Query问题

    关于springdata jpa 分页问题相信很多小伙伴都遇到过,只要表中数量到达分页条件就会报错 废话少说直接上代码: @Query(nativeQuery = true, value = &quo ...

  4. SpringData JPA查询分页demo

    SpringData JPA 的 PagingAndSortingRepository接口已经提供了对分页的支持,查询的时候我们只需要传入一个 org.springframework.data.dom ...

  5. 一篇 SpringData+JPA 总结

    概述 SpringData,Spring 的一个子项目,用于简化数据库访问,支持 NoSQL 和关系数据库存储 SpringData 项目所支持 NoSQL 存储 MongDB(文档数据库) Neo4 ...

  6. SpringData JPA复合主键

    上一篇博客简单介绍了SpringData JPA实现简单的CRUD,分页与多条件的排序,那里的主键类型是Long,有时我们会遇到主键不是一个的,复合主键,经过调研如下.确定一个人,不能只根据他的姓名来 ...

  7. SpringData JPA使用JPQL的方式查询和使用SQL语句查询

    使用Spring Data JPA提供的查询方法已经可以解决大部分的应用场景,但是对于某些业务来说,我们还需要灵活的构造查询条件, 这时就可以使用@Query注解,结合JPQL的语句方式完成查询 持久 ...

  8. 【持久层框架】- SpringData - JPA

    SpringData - JPA 生命不息,写作不止 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 一个有梦有戏的人 @怒放吧德德 分享学习心得,欢迎指正,大家一起学习成长! JPA简 ...

  9. Spring、SpringMVC、SpringData + JPA 整合详解

    原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7759874.html ------------------------------------ ...

随机推荐

  1. Python help() 函数

    Python help() 函数  Python 内置函数 描述 help() 函数用于查看函数或模块用途的详细说明. 语法 help 语法: help([object]) 参数说明: object ...

  2. js获取不到动态添加的标签的值的解决方法

    遇到了js无法获得动态添加的标签的值,百度了一番,最后自己解决了问题,但是原理现在还不怎么明确. $("input[id='txtAttValue']").each(functio ...

  3. Shiro01 功能点框图、架构图、身份认证逻辑、身份认证代码实现

    基本功能点 功能点框图 功能点说明 1.Authentication:身份认证/登录,验证用户是不是拥有相应的身份: 2.Authorization:授权,即权限验证,验证某个已认证的用户是否拥有某个 ...

  4. 理解数据库中的undo日志、redo日志、检查点

    数据库存放数据的文件,本文称其为data file. 数据库的内容在内存里是有缓存的,这里命名为db buffer.某次操作,我们取了数据库某表格中的数据,这个数据会在内存中缓存一些时间.对这个数据的 ...

  5. exe怎么找main函数

    先说DEBUG版本的命令行EXE main函数有两种,第一种是int main(),第二种是int main(int argc,char* argv[]) 不管哪种只要查找j___p___argc就能 ...

  6. Ubuntu在命令行下将默认语言改为英语

    将Ubuntu安装成中文版,需要将默认语言改为英文. 用vi(或nano等文本编辑器)打开 /etc/default/locale 文件 将原来的配置内容修改为 LANG=”en_US.UTF-8″ ...

  7. Java Thread系列(九)Master-Worker模式

    Java Thread系列(九)Master-Worker模式 Master-Worker模式是常用的并行设计模式. 一.Master-Worker 模式核心思想 Master-Worker 系统由两 ...

  8. nohup、&、setsid、fork和fg、bg究竟有啥区别?

    目录 目录 1 1. 名词解释 1 2. 什么是守护进程? 2 2.1. 后台运行 2 2.2. 解释关系 2 3. 以"&"方式运行有何问题? 2 4. fork 2 5 ...

  9. 深入浅出python系列(一)包与模块

    一.包 包是由一系列模块组成的,模块简单就说是一个.py文件.比如说,现在有一个数学功能组,可以计算加.减.乘.除.幂运算等等,假定把这几个功能分成几个模块,一个模块就是一个.py文件.由这些不同的模 ...

  10. (转)SQL Server内存遭遇操作系统进程压榨案例

    原文地址:http://www.cnblogs.com/zc_0101/p/3592259.html 场景: 最近一台DB服务器偶尔出现CPU报警,我的邮件报警阈(请读yù)值设置的是15%,开始时没 ...