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顺序,查询第二页,每页显示两个的查询结果:

转载于:https://www.cnblogs.com/boywwj/p/8026134.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【2021年,将Spring全家桶系列课程进行Review,修复顺序等错误。进入2022年,将Spring的课程进行整理,整理为案例精讲的系列课程,并新增高级的Spring Security等内容,通过手把手一步步教你从零开始学会应用Spring,课件将逐步进行上传,敬请期待】 本课程是Spring案例精讲课程的第四部分Spring Cloud,Spring案例精讲课程以真实场景、项目实战为导向,循序渐进,深入浅出的讲解Java网络编程,助力您在技术工作中更进一步。 本课程聚焦Spring Cloud的核心知识点:注册中心、服务提供者与消费者、服务的调用OpenFeign、Hystrix监控、服务网关gateway、消息驱动的微服务Spring Cloud Stream、分布式集群、分布式配置中心的案例介绍, 快速掌握Spring Cloud的核心知识,快速上手,为学习及工作做好充足的准备。 由于本课程聚焦于案例,即直接上手操作,对于Spring的原理等不会做过多介绍,希望了解原理等内容的需要通过其他视频或者书籍去了解,建议按照该案例课程一步步做下来,之后再去进一步回顾原理,这样能够促进大家对原理有更好的理解。【通过Spring全家桶,我们保证你能收获到以下几点】 1、掌握Spring全家桶主要部分的开发、实现2、可以使用Spring MVC、Spring Boot、Spring Cloud及Spring Data进行大部分的Spring开发3、初步了解使用微服务、了解使用Spring进行微服务的设计实现4、奠定扎实的Spring技术,具备了一定的独立开发的能力  【实力讲师】 毕业于清华大学软件学院软件工程专业,曾在Accenture、IBM等知名外企任管理及架构职位,近15年的JavaEE经验,近8年的Spring经验,一直致力于架构、设计、开发及管理工作,在电商、零售、制造业等有丰富的项目实施经验  【本课程适用人群】如果你是一定不要错过!  适合于有JavaEE基础的,如:JSP、JSTL、Java基础等的学习者没有基础的学习者跟着课程可以学习,但是需要补充相关基础知识后,才能很好的参与到相关的工作中。 【Spring全家桶课程共包含如下几门】 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值