在这篇文章中,我们公开了一个休息服务,它接受页面大小的可分页参数,并相应地排序和返回数据。
视频
本教程在下面的 Youtube 视频中进行了解释。让我们开始-
我们使用 H2 数据库。同样在 pom 中,我们添加了spring-boot-devtools的依赖项。这个 spring boot 依赖为我们提供了一个 H2-DB UI 界面。稍后我们将使用这个 UI 来填充 H2 中的数据。Maven将如下 -<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.javainuse</groupId>
<artifactId>SpringBootHelloWorld</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>SpringBootHelloWorld</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.1.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
创建 SpringBootHelloWorldApplication.java 如下 -
package com.javainuse;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RestController;
@RestController
@EnableAutoConfiguration
@SpringBootApplication
public class SpringBootHelloWorldApplication {
public static void main(String[] args) {
SpringApplication.run(SpringBootHelloWorldApplication.class, args);
}
}
创建实体类如下 -
package com.javainuse.model;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
@Entity
public class Employee {
@GeneratedValue(strategy = GenerationType.AUTO)
@Id
private long id;
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDept() {
return dept;
}
public void setDept(String dept) {
this.dept = dept;
}
private String dept;
@Override
public String toString() {
return "Employee [id=" + id + ", name=" + name + ", dept=" + dept + "]";
}
}
我们定义了一个 RestController,它将请求 /listPageable 映射到方法 employeesPageable。此方法将 Spring Pageable 作为参数。定义 RestController 如下 -
接下来我们定义 EmployeeRepository,它是一个扩展 Spring Framework 类 JpaRepository 的接口。JpaRepository 类是一个泛型,并采用以下两个参数作为参数 -
我们现在使用 H2 控制台在 H2 数据库中插入数据。转到localhost:8080/h2-console/login.do。
在 JDBC url 中使用jdbc:h2:mem:testdb。保持密码为空。单击连接。
Spring Boot 分页
package com.javainuse.controllers;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.javainuse.data.EmployeeRepository;
import com.javainuse.model.Employee;
@RestController
public class EmployeeController {
@Autowired
private EmployeeRepository employeeData;
@RequestMapping(value = "/listPageable", method = RequestMethod.GET)
Page<Employee> employeesPageable(Pageable pageable) {
return employeeData.findAll(pageable);
}
}
接下来我们定义 EmployeeRepository,它是一个扩展 Spring Framework 类 JpaRepository 的接口。JpaRepository 类是一个泛型,并采用以下两个参数作为参数 -
- 这个存储库将使用什么类型的对象——在我们的例子中是员工
- Id 将是什么类型的对象 - Long(因为 Employee 类中定义的 id 很长)
package com.javainuse.data;
import org.springframework.data.jpa.repository.JpaRepository;
import com.javainuse.model.Employee;
public interface EmployeeRepository extends JpaRepository<Employee
, Long> {
}
编译并运行 SpringBootHelloWorldApplication.java 作为 Java 应用程序。我们现在使用 H2 控制台在 H2 数据库中插入数据。转到localhost:8080/h2-console/login.do。
在 JDBC url 中使用jdbc:h2:mem:testdb。保持密码为空。单击连接。
现在选择 Employee 表。运行选择查询。接下来将测试数据添加到表中。
现在转到http://localhost:8080/listPageable?page=0&size=3&sort=name
我们可以看到仅返回 3 个元素,并根据名称进行排序。
下载源代码
下载它 -Spring Boot 分页