JPQL limit query
JPQL
does not provide a mechanism to limit queries. This is most often achieved by using the setMaxResults()
method on the Query
. If you must avoid specifying this in Java code, you could make a view in the database that contains your query and performs the limit. Then map an entity to this view as you would a table.
Example:
List<String> resultList= query.setMaxResults(100).getResultList();
In case you are working with spring-data you should use the Pageable Interface. A sample code below,
My Service,
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
@Service
public class MyModelService {
@Autowired
private MyModelRepository myModelRepository;
@Transactional
public Page<MyModel> findMyModelTop5() {
return myModelRepository.findMyModelTop5(new PageRequest(0, 5));
}
}
My Repository,
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
@Repository
public interface MyModelRepository extends JpaRepository<MyModel, Integer> {
@Query("SELECT mm FROM MyModel mm")
public Page<MyModel> findMyModelTop5(Pageable pageable);
}
You can find a more complete answer about the spring data available options here.