Spring JPA不写sql实现limit查询功能

Spring JPA不写sql实现limit查询功能

目前笔者收集到两种方式:
1、JPA默认没有直接支持limit,但我们可以使用JPA的分页+排序功能来实现limit的查询。代码如下:

import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Sort;
    //T 为model,需要有id字段,limit为指定的limit条数
    public List<T> findByIdDescLimit(int limit){
        return super.findAll(PageRequest.of(0,limit,Sort.by(Sort.Direction.DESC, "id"))).getContent();
    }

2、写dao实现,继承JpaRepository

 @Repository
public interface LongDao extends JpaRepository<LogDTO, Long>, JpaSpecificationExecutor<LogDTO> {
    List<LogDTO> findOrderByIdDesc(@Param("id") Long id);
}

然后在对结果集进行取前多少个的处理。。。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JPA在默认情况下没有直接支持limit,但可以通过使用JPA的分页+排序功能实现limit查询。一种方法是使用PageRequest和Sort来实现,代码如下: ```java import org.springframework.data.domain.PageRequest; import org.springframework.data.domain.Sort; // T为model,需要有id字段,limit为指定的limit条数 public List<T> findByIdDescLimit(int limit) { return super.findAll(PageRequest.of(0, limit, Sort.by(Sort.Direction.DESC, "id"))).getContent(); } ``` 另一种方法是在dao层实现,继承JpaRepository,并使用@Query注解来编写自定义查询语句,代码如下: ```java @Repository public interface LongDao extends JpaRepository<LogDTO, Long>, JpaSpecificationExecutor<LogDTO> { @Query("SELECT l FROM LogDTO l ORDER BY l.id DESC") List<LogDTO> findOrderByIdDesc(Pageable pageable); } ``` 其中,Pageable对象可以通过PageRequest来创建,指定查询的页数和每页的条数。通过调用findOrderByIdDesc方法并传入Pageable对象,即可实现带有limit查询。 请注意,以上代码仅为示例,具体实现可能需要根据你的实际情况进行调整。 #### 引用[.reference_title] - *1* *2* [Spring JPA不写sql实现limit查询功能](https://blog.csdn.net/A_C_Hunk/article/details/119389900)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [在JPA的@Query注解中使用limit条件(详解)](https://blog.csdn.net/u011250186/article/details/126017308)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值