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_05-文件操作

    目录: 1             文件操作 1.1          快速入门 1.1.1       用Python创建一个新文件 1.1.2       文件内容追加,从0到9的10个随机整数 ...

  2. Python setattr() 函数

    Python setattr() 函数  Python 内置函数 描述 setattr() 函数对应函数 getattr(),用于设置属性值,该属性不一定是存在的. 语法 setattr() 语法: ...

  3. info信息总结

    查询info信息 [[NSBundle mainBundle] infoDictionary] 以下是对应的输出 { BuildMachineOSBuild = 15C50; CFBundleDeve ...

  4. 阿里云EIP按流量计费

    https://help.aliyun.com/document_detail/27767.html 计费周期为1小时,账单周期也为1小时.在一个计费周期内,如果您使用的时间不足一小时,按一小时收费. ...

  5. python 探测网站目录的GUI程序-乾颐堂

    1.pyqt4写的界面 find_ui.py 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 ...

  6. SpringMvc 全局异常处理器定义,友好的返回后端错误信息

    import com.google.common.collect.Maps; import org.apache.log4j.Logger; import org.springframework.be ...

  7. 5 Django-2 的路由层 (URLconf)

    URL 配置 (URLconf) 就像 Django 所支撑网站的目录.它的本质是 URL 与要为该 URL 调用的视图函数之间的映射表:你就是以这种方式告诉 Django,对于客户端发来的某个 UR ...

  8. platform总线驱动代码分析

    /************************************************************************/ Linux内核版本:2.6.35.7 运行平台:三 ...

  9. windows7文件夹怎样默认图片大图显示?

    先打开一个含有图片的文件夹,在文件夹空白处右键选择属性,打开自定义选项卡. 确定自定义选项卡 显示的是:“优化此文件夹:图片”. 然后,选择:组织--文件夹和搜索选项--查看--文件夹视图,应用到文件 ...

  10. UILabel 字体下方加下划线

        UILabel *knowKankan = [[UILabel alloc] initWithFrame:CGRectMake(0, MAINHEIGHT - 78 , MAINWIDTH, ...