前提・実現したいこと
SpringBootのJPAを使用して、SQLを実行させたいです。
呼ばれる際のリクエストにlimit,offset句の値を渡してもらって今のページ番号での結果を返したいです。
発生している問題・エラーメッセージ
Caused by: java.lang.IllegalArgumentException: Paging query needs to have a Pageable parameter! Offending method public abstract org.springframework.data.domain.Page com.test.testweb.repositories.TestPostRepository.findByTestPost(org.springframework.data.domain.PageRequest) at org.springframework.util.Assert.isTrue(Assert.java:116) at org.springframework.data.repository.query.QueryMethod.<init>(QueryMethod.java:99) at org.springframework.data.jpa.repository.query.JpaQueryMethod.<init>(JpaQueryMethod.java:95) at org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy$AbstractQueryLookupStrategy.resolveQuery(JpaQueryLookupStrategy.java:79) at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.lookupQuery(RepositoryFactorySupport.java:553) at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.lambda$mapMethodsToQuery$1(RepositoryFactorySupport.java:546) at java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:193) at java.util.Iterator.forEachRemaining(Iterator.java:116) at java.util.Collections$UnmodifiableCollection$1.forEachRemaining(Collections.java:1049) at java.util.Spliterators$IteratorSpliterator.forEachRemaining(Spliterators.java:1801) at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481) at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471) at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708) at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499) at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.mapMethodsToQuery(RepositoryFactorySupport.java:548) at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.lambda$new$0(RepositoryFactorySupport.java:538) at java.util.Optional.map(Optional.java:215) at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.<init>(RepositoryFactorySupport.java:538) at org.springframework.data.repository.core.support.RepositoryFactorySupport.getRepository(RepositoryFactorySupport.java:317) at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.lambda$afterPropertiesSet$3(RepositoryFactoryBeanSupport.java:286) at org.springframework.data.util.Lazy.getNullable(Lazy.java:141) at org.springframework.data.util.Lazy.get(Lazy.java:63) at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.afterPropertiesSet(RepositoryFactoryBeanSupport.java:289) at org.springframework.data.jpa.repository.support.JpaRepositoryFactoryBean.afterPropertiesSet(JpaRepositoryFactoryBean.java:102) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1758) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1695) ... 47 common frames omitted
該当のソースコード
・サービスクラス
Java
1public Page<TestPostResponse> getTestPostList(int limit, int offset) { 2 Page<TestPostResponse> response = testPostRepository.findByTestPost(PageRequest.of(offset, limit)); 3 return response 4 }
・リポジトリクラス
Java
1 @Query( 2 value = 3 "SELECT "+ 4 "p.id AS id, " + 5 "u.user_name AS userName, " + 6 "u.user_key AS userId, " + 7 "u.thumbnail_url AS thumbnailUrl, " + 8 "p.post_body AS postBody, " + 9 "p.post_picture AS postPicture, " + 10 "p.release_member_flag AS releaseMemberFlag, " + 11 "p.pin_flag AS pinFlag " + 12 "FROM " + 13 "posts AS p " + 14 "INNER JOIN " + 15 "users AS u " + 16 "ON " + 17 "p.user_id = u.id " + 18 "WHERE " + 19 "p.release_member_flag IS NULL", 20 countQuery = 21 "SELECT " + 22 "count(*) AS count " + 23 "FROM " + 24 "posts AS p " + 25 "INNER JOIN " + 26 "users AS u " + 27 "ON " + 28 "p.user_id = u.id " + 29 "WHERE " + 30 "p.release_member_flag IS NULL", 31 nativeQuery = true) 32 Page<TestPostResponse> findByTestPost(PageRequest of);
試したこと
findAllでは問題なく取れるのですが、NativeQueryのSQLにもあるように、該当の条件に値するもののみ取得したいのでfindAllだと想定外のデータも返って来てしまいます。
NativeQueryでSQLを作成したのですが、それでは提示のエラーが実行時エラーとして返って来てしまいます。
補足情報(FW/ツールのバージョンなど)
Java8
Spring Boot
あなたの回答
tips
プレビュー