SpringData JPA实现CRUD,分页与多参数排序
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,分页与多参数排序的更多相关文章
- SpringData JPA快速入门和基本的CRUD操作以及Specifications条件查询
SpringData JPA概述: SpringData JPA 是 Spring 基于 ORM 框架.JPA 规范的基础上封装的一套JPA应用框架,可使开发者用极简的代码即可实现对数据库的访问和操作 ...
- Spring Boot CRUD+分页(基于JPA规范)
步骤一:JPA概念 JPA(Java Persistence API)是Sun官方提出的Java持久化规范,用来方便大家操作数据库. 真正干活的可能是Hibernate,TopLink等等实现了JPA ...
- springdata jpa 关于分页@Query问题
关于springdata jpa 分页问题相信很多小伙伴都遇到过,只要表中数量到达分页条件就会报错 废话少说直接上代码: @Query(nativeQuery = true, value = &quo ...
- SpringData JPA查询分页demo
SpringData JPA 的 PagingAndSortingRepository接口已经提供了对分页的支持,查询的时候我们只需要传入一个 org.springframework.data.dom ...
- 一篇 SpringData+JPA 总结
概述 SpringData,Spring 的一个子项目,用于简化数据库访问,支持 NoSQL 和关系数据库存储 SpringData 项目所支持 NoSQL 存储 MongDB(文档数据库) Neo4 ...
- SpringData JPA复合主键
上一篇博客简单介绍了SpringData JPA实现简单的CRUD,分页与多条件的排序,那里的主键类型是Long,有时我们会遇到主键不是一个的,复合主键,经过调研如下.确定一个人,不能只根据他的姓名来 ...
- SpringData JPA使用JPQL的方式查询和使用SQL语句查询
使用Spring Data JPA提供的查询方法已经可以解决大部分的应用场景,但是对于某些业务来说,我们还需要灵活的构造查询条件, 这时就可以使用@Query注解,结合JPQL的语句方式完成查询 持久 ...
- 【持久层框架】- SpringData - JPA
SpringData - JPA 生命不息,写作不止 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 一个有梦有戏的人 @怒放吧德德 分享学习心得,欢迎指正,大家一起学习成长! JPA简 ...
- Spring、SpringMVC、SpringData + JPA 整合详解
原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7759874.html ------------------------------------ ...
随机推荐
- Python help() 函数
Python help() 函数 Python 内置函数 描述 help() 函数用于查看函数或模块用途的详细说明. 语法 help 语法: help([object]) 参数说明: object ...
- js获取不到动态添加的标签的值的解决方法
遇到了js无法获得动态添加的标签的值,百度了一番,最后自己解决了问题,但是原理现在还不怎么明确. $("input[id='txtAttValue']").each(functio ...
- Shiro01 功能点框图、架构图、身份认证逻辑、身份认证代码实现
基本功能点 功能点框图 功能点说明 1.Authentication:身份认证/登录,验证用户是不是拥有相应的身份: 2.Authorization:授权,即权限验证,验证某个已认证的用户是否拥有某个 ...
- 理解数据库中的undo日志、redo日志、检查点
数据库存放数据的文件,本文称其为data file. 数据库的内容在内存里是有缓存的,这里命名为db buffer.某次操作,我们取了数据库某表格中的数据,这个数据会在内存中缓存一些时间.对这个数据的 ...
- exe怎么找main函数
先说DEBUG版本的命令行EXE main函数有两种,第一种是int main(),第二种是int main(int argc,char* argv[]) 不管哪种只要查找j___p___argc就能 ...
- Ubuntu在命令行下将默认语言改为英语
将Ubuntu安装成中文版,需要将默认语言改为英文. 用vi(或nano等文本编辑器)打开 /etc/default/locale 文件 将原来的配置内容修改为 LANG=”en_US.UTF-8″ ...
- Java Thread系列(九)Master-Worker模式
Java Thread系列(九)Master-Worker模式 Master-Worker模式是常用的并行设计模式. 一.Master-Worker 模式核心思想 Master-Worker 系统由两 ...
- nohup、&、setsid、fork和fg、bg究竟有啥区别?
目录 目录 1 1. 名词解释 1 2. 什么是守护进程? 2 2.1. 后台运行 2 2.2. 解释关系 2 3. 以"&"方式运行有何问题? 2 4. fork 2 5 ...
- 深入浅出python系列(一)包与模块
一.包 包是由一系列模块组成的,模块简单就说是一个.py文件.比如说,现在有一个数学功能组,可以计算加.减.乘.除.幂运算等等,假定把这几个功能分成几个模块,一个模块就是一个.py文件.由这些不同的模 ...
- (转)SQL Server内存遭遇操作系统进程压榨案例
原文地址:http://www.cnblogs.com/zc_0101/p/3592259.html 场景: 最近一台DB服务器偶尔出现CPU报警,我的邮件报警阈(请读yù)值设置的是15%,开始时没 ...