微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在本机查询 JPA 中传递参数

如何解决如何在本机查询 JPA 中传递参数

我有服务类,它通过使用 carRepository.retrieveCars() 调用 JPA 存储库来接收汽车列表。 Repository 方法是使用本机查询来检索记录。

public interface CarRepository extends JpaRepository<Car,String> {
    @Query(nativeQuery = true,value = "select *" +
                   "from car_records")
 }
 List<Car> retrieveCars(); 

现在我想传递参数 carRepository.retrieveCars(Long vinNo,Long serialNo) 并在查询中使用它们。我假设我需要一些东西作为准备好的陈述。但是我不确定如何实现。

public interface CarRepository extends JpaRepository<TRace,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); 

解决方法

当您使用 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); 
    }

spring doc for named parameters

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); 
}

example for index parameter from spring doc

然后从您的服务类中调用它

carRepository.retrieveCars(vinNo,serialNo);

这两种情况对你来说都是一样的。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。