Mar*_*Mar 28 java sql spring jpa spring-data-jpa
我有一个服务类,它通过使用 调用 JPA 存储库来接收汽车列表carRepository.retrieveCars()。存储库方法使用本机查询来检索记录。
public interface CarRepository extends JpaRepository<Car, String> {
@Query(nativeQuery = true,
value = "select *" +
"from car_records")
}
List<Car> retrieveCars();
Run Code Online (Sandbox Code Playgroud)
现在我想传递参数carRepository.retrieveCars(Long vinNo, Long serialNo)并在查询中使用它们。我想我需要一些东西作为准备好的陈述。但是我不确定如何实现。
public interface CarRepository extends JpaRepository<TRace, String> {
@Query(nativeQuery = true,
value = "select *" +
"from car_records" +
"where carVinNo = ?! and carSerialNo >= ?1")
}
query.setParameter(1, vinNo, 2,serialNo); //this is certainly not correct implementation
List<Car> retrieveCars(vinNo, serialNo);
Run Code Online (Sandbox Code Playgroud)
Pan*_*kos 32
使用 Spring Data JPA 时有两种方法可以解决这个问题
1) 命名参数
public interface CarRepository extends JpaRepository<TRace, String> {
@Query(nativeQuery = true,
value = "select *" +
"from car_records" +
"where carVinNo = :vinNo and carSerialNo >= :serialNo")
}
List<Car> retrieveCars(@Param("vinNo") Long vinNo,@Param("serialNo") Long serialNo);
}
Run Code Online (Sandbox Code Playgroud)
2) 索引参数
public interface CarRepository extends JpaRepository<TRace, String> {
@Query(nativeQuery = true,
value = "select *" +
"from car_records" +
"where carVinNo = ?1 and carSerialNo >= ?2")
}
List<Car> retrieveCars(Long vinNo, Long serialNo);
}
Run Code Online (Sandbox Code Playgroud)
然后从你的服务类中调用它
carRepository.retrieveCars(vinNo, serialNo);
Run Code Online (Sandbox Code Playgroud)
这两种情况对您来说都是一样的。
| 归档时间: |
|
| 查看次数: |
88765 次 |
| 最近记录: |