一、使用where条件
上一篇我们使用JPA进行了数据源的访问,默认JPA已经实现了好几个接口可以调用。但是,在实际的业务中,查询语句不可避免地需要使用where、order by等语句。

我们用商品数据来做例子,添加一个价格字段price,按价格范围查询,看看怎么来实现。

方式一:通过方法名称来实现
public interface GoodsRepository extends JpaRepository<Goods, Long> {
List<Goods> findByPriceBetween(Double startPrice, Double endPrice);
}
Spring Data JPA 查询方法支持的关键字(可参考:https://docs.spring.io/spring-data/jpa/docs/2.2.x/reference/html/#repositories.query-methods)

Table 2.2. Supported keywords inside method names

方式二:通过自定义SQL来实现
在现实中,可能会含有非常复杂的SQL语句,或者为了性能优化,我们需要自定义sql。JPA提供注解和XML配置这2中方式。

public interface GoodsRepository extends JpaRepository<Goods, Long> {
@Query(value = "select * from goods g where g.price between :startPrice and :endPrice", nativeQuery = true)
List<Goods> findByPriceBetween(Double startPrice, Double endPrice);
}
二、order by查询
使用order by也可以编写在方法名上,可以把以上例子改为

public interface GoodsRepository extends JpaRepository<Goods, Long> {
List<Goods> findByPriceBetweenOrderByPriceAsc(Double startPrice, Double endPrice);

————————————————
版权声明:本文为CSDN博主「loophome」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/loophome/article/details/87186778

最新文章

  1. sqlserver 自增ID插入指定数据
  2. Eclipse搭建Python开发环境+Python中文处理
  3. bat自动执行telnet
  4. php 字符串式非关联数组循环
  5. Innodb中的事务隔离级别和锁的关系(转)
  6. 【JAVA错误笔记】 - Unable add facets project AnnotationWebService CXF 2-x Web Services
  7. 《Hadoop权威》学习笔记四:Hadoop的I/O
  8. Memcache存储大量数据的问题
  9. Android中build&#160;target,minSdkVersion,targetSdkVersion,maxSdkVersion概念区分
  10. Unity使用脚本进行批量动态加载贴图
  11. EFCore动态切换Schema
  12. Spring笔记04_AOP注解开发_模板_事务
  13. 使用K-means进行聚类,用calinski_harabaz_score评价聚类效果
  14. shell丢弃信息
  15. jquery .On()绑定事件的触发机制
  16. Python traceback 模块,追踪错误
  17. leetcode python 008
  18. JSCS: Please specify path to &#39;JSCS&#39; package
  19. 学习quartz
  20. HttpURLConnection类的使用

热门文章

  1. Java 之 Object 类
  2. Java 面向对象—杂项(方法不能重写,修饰符,变量)
  3. TP5给request对象动态绑定属性
  4. OCR6:Custom Traineddata
  5. SQL注入之Sqlmap使用
  6. php怎么识别真实ip
  7. python应用-解决应用题
  8. 学习:Windows API核心DLL文件
  9. Educational Codeforces F. Remainder Problem
  10. Mobius