原文: http://zetcode.com/springboot/findbyid/

Spring Boot findById教程展示了如何使用CrudRepositoryfindById方法通过其 ID 检索实体。

Spring 是用于创建企业应用的流行 Java 应用框架。 Spring Boot 是 Spring 框架的演进,可帮助您轻松创建独立的,生产级的基于 Spring 的应用。

CrudRepository

CrudRepository接口在存储库中为特定类型提供通用 CRUD 操作。 其findById()方法通过其 ID 检索实体。 返回值为Optional<T>

Optional<T>是一个容器对象,可能包含也可能不包含非空值。 如果存在值,则isPresent()返回trueget()返回该值。 如果存在该值,则ifPresent()会调用指定的方法; 否则什么都不做。

Spring Boot findById 示例

以下应用设置了City对象的存储库。 在控制台运行器中,我们通过其 ID 检索城市对象。

  1. pom.xml
  2. src
  3. ├───main
  4. ├───java
  5. └───com
  6. └───zetcode
  7. Application.java
  8. MyRunner.java
  9. ├───model
  10. City.java
  11. ├───repository
  12. CityRepository.java
  13. └───service
  14. CityService.java
  15. ICityService.java
  16. └───resources
  17. application.properties
  18. data-h2.sql
  19. schema-h2.sql
  20. └───test
  21. └───java

这是项目结构。

pom.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
  5. http://maven.apache.org/xsd/maven-4.0.0.xsd">
  6. <modelVersion>4.0.0</modelVersion>
  7. <groupId>com.zetcode</groupId>
  8. <artifactId>sprinbootfindbyid</artifactId>
  9. <version>1.0-SNAPSHOT</version>
  10. <packaging>jar</packaging>
  11. <properties>
  12. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  13. <maven.compiler.source>11</maven.compiler.source>
  14. <maven.compiler.target>11</maven.compiler.target>
  15. </properties>
  16. <parent>
  17. <groupId>org.springframework.boot</groupId>
  18. <artifactId>spring-boot-starter-parent</artifactId>
  19. <version>2.1.1.RELEASE</version>
  20. </parent>
  21. <dependencies>
  22. <dependency>
  23. <groupId>org.springframework.boot</groupId>
  24. <artifactId>spring-boot-starter-data-jpa</artifactId>
  25. </dependency>
  26. <dependency>
  27. <groupId>com.h2database</groupId>
  28. <artifactId>h2</artifactId>
  29. <scope>runtime</scope>
  30. </dependency>
  31. </dependencies>
  32. <build>
  33. <plugins>
  34. <plugin>
  35. <groupId>org.springframework.boot</groupId>
  36. <artifactId>spring-boot-maven-plugin</artifactId>
  37. </plugin>
  38. </plugins>
  39. </build>
  40. </project>

Maven POM 文件包含 Spring Data JPA 和 H2 数据库的依赖项。

resources/application.properties

  1. spring.main.banner-mode=off
  2. spring.datasource.platform=h2
  3. spring.jpa.hibernate.ddl-auto=none

application.properties是 Spring Boot 的主要配置文件。 Spring Boot 横幅使用spring.main.banner-mode属性关闭。

spring.datasource.platform设置数据库的供应商名称。 在初始化脚本中使用它。 spring.jpa.hibernate.ddl-auto禁止从实体自动创建模式。

resources/schema-h2.sql

  1. CREATE TABLE cities(id INT PRIMARY KEY AUTO_INCREMENT,
  2. name VARCHAR(255), population INT);

启动应用时,将执行schema-h2.sql脚本。 它创建一个新的数据库表。

resources/data-h2.sql

  1. INSERT INTO cities(name, population) VALUES('Bratislava', 432000);
  2. INSERT INTO cities(name, population) VALUES('Budapest', 1759000);
  3. INSERT INTO cities(name, population) VALUES('Prague', 1280000);
  4. INSERT INTO cities(name, population) VALUES('Warsaw', 1748000);
  5. INSERT INTO cities(name, population) VALUES('Los Angeles', 3971000);
  6. INSERT INTO cities(name, population) VALUES('New York', 8550000);
  7. INSERT INTO cities(name, population) VALUES('Edinburgh', 464000);
  8. INSERT INTO cities(name, population) VALUES('Suzhou', 4327066);
  9. INSERT INTO cities(name, population) VALUES('Zhengzhou', 4122087);
  10. INSERT INTO cities(name, population) VALUES('Berlin', 3671000);

该表中填充了data-h2.sql文件中的数据。

com/zetcode/model/City.java

  1. package com.zetcode.model;
  2. import java.util.Objects;
  3. import javax.persistence.Entity;
  4. import javax.persistence.GeneratedValue;
  5. import javax.persistence.GenerationType;
  6. import javax.persistence.Id;
  7. import javax.persistence.Table;
  8. @Entity
  9. @Table(name = "cities")
  10. public class City {
  11. @Id
  12. @GeneratedValue(strategy = GenerationType.AUTO)
  13. private Long id;
  14. private String name;
  15. private int population;
  16. public City() {
  17. }
  18. public City(String name, int population) {
  19. this.name = name;
  20. this.population = population;
  21. }
  22. public Long getId() {
  23. return id;
  24. }
  25. public void setId(Long id) {
  26. this.id = id;
  27. }
  28. public String getName() {
  29. return name;
  30. }
  31. public void setName(String name) {
  32. this.name = name;
  33. }
  34. public int getPopulation() {
  35. return population;
  36. }
  37. public void setPopulation(int population) {
  38. this.population = population;
  39. }
  40. @Override
  41. public int hashCode() {
  42. int hash = 7;
  43. hash = 79 * hash + Objects.hashCode(this.id);
  44. hash = 79 * hash + Objects.hashCode(this.name);
  45. hash = 79 * hash + this.population;
  46. return hash;
  47. }
  48. @Override
  49. public boolean equals(Object obj) {
  50. if (this == obj) {
  51. return true;
  52. }
  53. if (obj == null) {
  54. return false;
  55. }
  56. if (getClass() != obj.getClass()) {
  57. return false;
  58. }
  59. final City other = (City) obj;
  60. if (this.population != other.population) {
  61. return false;
  62. }
  63. if (!Objects.equals(this.name, other.name)) {
  64. return false;
  65. }
  66. return Objects.equals(this.id, other.id);
  67. }
  68. @Override
  69. public String toString() {
  70. var builder = new StringBuilder();
  71. builder.append("City{id=").append(id).append(", name=")
  72. .append(name).append(", population=")
  73. .append(population).append("}");
  74. return builder.toString();
  75. }
  76. }

这是City实体。

com/zetcode/repository/CityRepository.java

  1. package com.zetcode.repository;
  2. import com.zetcode.model.City;
  3. import org.springframework.data.repository.CrudRepository;
  4. import org.springframework.stereotype.Repository;
  5. @Repository
  6. public interface CityRepository extends CrudRepository<City, Long> {
  7. }

通过从 Spring CrudRepository扩展,我们为实现数据库提供了一些基本方法。

com/zetcode/service/ICityService.java

  1. package com.zetcode.service;
  2. import com.zetcode.model.City;
  3. import java.util.Optional;
  4. public interface ICityService {
  5. Optional<City> findById(Long id);
  6. }

ICityService提供了一种通过城市 ID 来获取城市的契约方法。

com/zetcode/service/CityService.java

  1. package com.zetcode.service;
  2. import com.zetcode.model.City;
  3. import com.zetcode.repository.CityRepository;
  4. import org.springframework.beans.factory.annotation.Autowired;
  5. import org.springframework.stereotype.Service;
  6. import java.util.Optional;
  7. @Service
  8. public class CityService implements ICityService {
  9. @Autowired
  10. private CityRepository cityRepository;
  11. @Override
  12. public Optional<City> findById(Long id) {
  13. return cityRepository.findById(id);
  14. }
  15. }

CityService包含findById()方法的实现。 我们使用存储库从数据库检索数据。

  1. @Autowired
  2. private CityRepository repository;

注入CityRepository

  1. @Override
  2. public Optional<City> findById(Long id) {
  3. return cityRepository.findById(id);
  4. }

findById()返回Optional<City>

com/zetcode/MyRunner.java

  1. package com.zetcode;
  2. import com.zetcode.service.ICityService;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.boot.CommandLineRunner;
  5. import org.springframework.stereotype.Component;
  6. @Component
  7. public class MyRunner implements CommandLineRunner {
  8. @Autowired
  9. private ICityService cityService;
  10. @Override
  11. public void run(String... args) throws Exception {
  12. var id1 = 2L;
  13. cityService.findById(id1).ifPresent(System.out::println);
  14. var id2 = 24L;
  15. var val = cityService.findById(id2);
  16. if (val.isPresent()) {
  17. System.out.println(val.get());
  18. } else {
  19. System.out.printf("No city found with id %d%n", id2);
  20. }
  21. }
  22. }

MyRunner中,我们寻找两个城市实体。

  1. var id1 = 2L;
  2. cityService.findById(id1).ifPresent(System.out::println);

我们通过其 ID 查找城市,如果存在,则将其打印到控制台。 否则,不打印任何内容。

  1. var id2 = 24L;
  2. var val = cityService.findById(id2);
  3. if (val.isPresent()) {
  4. System.out.println(val.get());
  5. } else {
  6. System.out.printf("No city found with id %d%n", id2);
  7. }

在第二种情况下,我们使用isPresent()检查值的存在。 如果存在值,我们将其打印出来。 如果没有,我们会打印一条消息,提示找不到该城市。

com/zetcode/Application.java

  1. package com.zetcode;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. @SpringBootApplication
  5. public class Application {
  6. public static void main(String[] args) {
  7. SpringApplication.run(Application.class, args);
  8. }
  9. }

Application设置 Spring Boot 应用。 @SpringBootApplication启用自动配置和组件扫描。

  1. $ mvn spring-boot:run -q
  2. ...
  3. City{id=2, name=Budapest, population=1759000}
  4. No city found with id 24
  5. ...

我们运行该应用。

在本教程中,我们展示了如何使用CrudRepositoryfindById()方法查找特定实体。 您可能也对相关教程感兴趣:

列出所有 Spring Boot 教程