首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ParameterBinding所需的名称不适用于可分页

ParameterBinding所需的名称不适用于可分页
EN

Stack Overflow用户
提问于 2018-01-26 20:42:06
回答 2查看 292关注 0票数 0

我正在尝试执行一个查询,使用带有paegable的mySql fullText索引"match query“语法。

我将spring-boot版本从1.5.4.RELEASE更改为2.0.0m7,以使用spring-data-jpa版本2.0.2.RELEASE,因为在早期的spring-data-jpa版本中,带有countQuery的原生查询不起作用。

我已经使用解决方案herehere修复了几个问题。

当前的问题是以下错误:

代码语言:javascript
复制
javax.servlet.ServletException: org.springframework.orm.jpa.JpaSystemException: could not execute query; nested exception is org.hibernate.exception.GenericJDBCException: could not execute query
...
Caused by: java.sql.SQLException: Parameter index out of range (2 > number of parameters, which is 1).

下面是代码

代码语言:javascript
复制
@Query( value = "SELECT Distinct u.* " +
    "FROM user AS u " +
    "WHERE MATCH(u.name, u.email) against(:filterValue) " +
    "ORDER BY u.id \n#pageable\n#",
    countQuery = "SELECT count(Distinct u.id) " +
    "FROM user AS u " +
    "WHERE MATCH(u.name, u.email) against(:filterValue) " +
    "ORDER BY u.id \n#pageable\n#",
    nativeQuery = true)
Page<User> foo(@Param("filterValue") String filterValue, Pageable pageable);

如果我也尝试将可分页设置为参数,同样的错误也会发生。

有什么想法吗?

EN

回答 2

Stack Overflow用户

发布于 2018-01-26 23:19:36

您不必在查询中显式地包含可分页。

请参阅the reference documentation中的示例。

代码语言:javascript
复制
public interface UserRepository extends JpaRepository<User, Long> {

  @Query(value = "SELECT * FROM USERS WHERE LASTNAME = ?1",
    countQuery = "SELECT count(*) FROM USERS WHERE LASTNAME = ?1",
    nativeQuery = true)
  Page<User> findByLastname(String lastname, Pageable pageable);
}

我强烈建议您升级到Spring Data的当前发布版本,而不是里程碑版本。

票数 0
EN

Stack Overflow用户

发布于 2018-01-26 21:04:36

试着把可分页放在第一位:

代码语言:javascript
复制
Page<User> foo(Pageable pageable, @Param("filterValue") String filterValue);
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48461595

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档