- Spring Boot JPA 教程
- Spring Boot JPA - 主页
- Spring Boot JPA - 概述
- Spring Boot JPA - 环境设置
- Spring Boot JPA - 架构
- Spring Boot JPA 与 Hibernate
- Spring Boot JPA - 应用设置
- Spring Boot JPA - 单元测试仓库
- Spring Boot JPA - 方法
- Spring Boot JPA - 自定方法
- Spring Boot JPA - 命名查询
- Spring Boot JPA - 自定查询
- Spring Boot JPA - 原生查询
- Spring Boot JPA 实用资源
- Spring Boot JPA - 快速指南
- Spring Boot JPA - 实用资源
- Spring Boot JPA - 讨论
Spring Boot JPA - 原生查询
有时候我们需要一个自定原生查询来完成一个测试用例。我们可以在仓库中使用 @Query 注释来指定一个查询。下面是一个示例。在这个示例中,我们正在使用原生查询,并设置了 Query 注释中的属性 nativeQuery=true 以将查询标记为原生查询。
我们在 JPA 自定查询 章节中向仓库添加了自定方法。现在,让我们添加一个使用原生查询的方法并对其进行测试。
Repository - EmployeeRepository.java
添加一个方法以按员工姓名获取员工列表。
package com.tutorialspoint.repository; import org.springframework.data.jpa.repository.Query; import org.springframework.data.repository.CrudRepository; import org.springframework.stereotype.Repository; import com.tutorialspoint.entity.Employee; @Repository public interface EmployeeRepository extends CrudRepository<Employee, Integer> { public List<Employee> findByName(String name); public List<Employee> findByAge(int age); public Employee findByEmail(String email); @Query(value = "SELECT e FROM Employee e ORDER BY name") public List<Employee> findAllSortedByName(); @Query(value = "SELECT * FROM Employee ORDER BY name", nativeQuery = true) public List<Employee> findAllSortedByNameUsingNative(); }
让我们通过向测试文件中添加测试用例来测试添加的方法。下面文件中的最后两种方法测试了添加的自定查询方法。
示例
以下是 EmployeeRepositoryTest 的完整代码。
package com.tutorialspoint.repository; import static org.junit.jupiter.api.Assertions.assertEquals; import java.util.ArrayList; import java.util.List; import javax.transaction.Transactional; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit.jupiter.SpringExtension; import com.tutorialspoint.entity.Employee; import com.tutorialspoint.sprintbooth2.SprintBootH2Application; @ExtendWith(SpringExtension.class) @Transactional @SpringBootTest(classes = SprintBootH2Application.class) public class EmployeeRepositoryTest { @Autowired private EmployeeRepository employeeRepository; @Test public void testFindById() { Employee employee = getEmployee(); employeeRepository.save(employee); Employee result = employeeRepository.findById(employee.getId()).get(); assertEquals(employee.getId(), result.getId()); } @Test public void testFindAll() { Employee employee = getEmployee(); employeeRepository.save(employee); List<Employee> result = new ArrayList<>(); employeeRepository.findAll().forEach(e -> result.add(e)); assertEquals(result.size(), 1); } @Test public void testSave() { Employee employee = getEmployee(); employeeRepository.save(employee); Employee found = employeeRepository.findById(employee.getId()).get(); assertEquals(employee.getId(), found.getId()); } @Test public void testDeleteById() { Employee employee = getEmployee(); employeeRepository.save(employee); employeeRepository.deleteById(employee.getId()); List<Employee> result = new ArrayList<>(); employeeRepository.findAll().forEach(e -> result.add(e)); assertEquals(result.size(), 0); } private Employee getEmployee() { Employee employee = new Employee(); employee.setId(1); employee.setName("Mahesh"); employee.setAge(30); employee.setEmail("[email protected]"); return employee; } @Test public void testFindByName() { Employee employee = getEmployee(); employeeRepository.save(employee); List<Employee> result = new ArrayList<>(); employeeRepository.findByName(employee.getName()).forEach(e -> result.add(e)); assertEquals(result.size(), 1); } @Test public void testFindByAge() { Employee employee = getEmployee(); employeeRepository.save(employee); List<Employee> result = new ArrayList<>(); employeeRepository.findByAge(employee.getAge()).forEach(e -> result.add(e)); assertEquals(result.size(), 1); } @Test public void testFindByEmail() { Employee employee = getEmployee(); employeeRepository.save(employee); Employee result = employeeRepository.findByEmail(employee.getEmail()); assertNotNull(result); } @Test public void testFindAllSortedByName() { Employee employee = getEmployee(); Employee employee1 = new Employee(); employee1.setId(2); employee1.setName("Aarav"); employee1.setAge(20); employee1.setEmail("[email protected]"); employeeRepository.save(employee); employeeRepository.save(employee1); List<Employee> result = employeeRepository.findAllSortedByName(); assertEquals(employee1.getName(), result.get(0).getName()); } @Test public void testFindAllSortedByNameUsingNative() { Employee employee = getEmployee(); Employee employee1 = new Employee(); employee1.setId(2); employee1.setName("Aarav"); employee1.setAge(20); employee1.setEmail("[email protected]"); employeeRepository.save(employee); employeeRepository.save(employee1); List<Employee> result = employeeRepository.findAllSortedByNameUsingNative(); assertEquals(employee1.getName(), result.get(0).getName()); } }
运行测试用例
输出
右键单击 eclipse 中的文件,选择 运行 JUnit 测试 并验证结果。
广告