Spring data jpa, pageable 向自定义查询添加自己的规范

如何解决Spring data jpa, pageable 向自定义查询添加自己的规范

我有问题。我正在尝试通过使用时间戳按日期过滤来进行自定义查询,但我使用的是 Pageable 并且它在逗号 id desc 限制之后添加查询中,并导致如下错误。我不知道如何解决这个问题。

select * from lights Where timestamp BETWEEN ? AND ? ORDER BY id LIMIT 999999,id desc limit ?
2021-03-05 15:49:59.545 TRACE 896 --- [nio-8080-exec-1] o.h.type.descriptor.sql.BasicBinder      : binding parameter [1] as [VARCHAR] - ['2021-03-04 15:27:07']
2021-03-05 15:49:59.545 TRACE 896 --- [nio-8080-exec-1] o.h.type.descriptor.sql.BasicBinder      : binding parameter [2] as [VARCHAR] - ['2999-12-31 23:59:59']
2021-03-05 15:49:59.556  WARN 896 --- [nio-8080-exec-1] o.h.engine.jdbc.spi.sqlExceptionHelper   : sql Error: 1064,sqlState: 42000
2021-03-05 15:49:59.556 ERROR 896 --- [nio-8080-exec-1] o.h.engine.jdbc.spi.sqlExceptionHelper   : You have an error in your sql Syntax; check the manual that corresponds to your MysqL server version for the right Syntax to use near 'desc limit 300' at line 1

自定义查询

    @Query(nativeQuery = true,value = "select * from lights Where timestamp BETWEEN :startDate AND :endDate ORDER BY id LIMIT 999999")
    Page<Lights> findBetweenDates(@Param("startDate") String startDate,@Param("endDate") String endDate,Pageable pageable);

控制器类

    @GetMapping("/lights")
    public String viewHomePage(Model model,String startDate,String endDate) {
        startDate = "'2021-03-04 15:27:07'";
        endDate = "'2999-12-31 23:59:59'";
        return findPaginated(1,"id","desc",startDate,endDate,model);
    }

    @RequestMapping({"/lights/page/{pageNo}"})
    public String findPaginated(@PathVariable(value = "pageNo") int pageNo,@RequestParam("sortField" ) String sortField,@RequestParam("sortDir") String sortDir,@RequestParam(value = "startDate",defaultValue = "'2021-03-04 15:27:07'") String startDate,@RequestParam(value = "endDate",defaultValue = "'2999-12-31 23:59:59'") String endDate,Model model){
        int pageSize = 200;


        Page<Lights> page = lightsMapService.findPaginated(pageNo,pageSize,sortField,sortDir,endDate);
        List<Lights> lightsList = page.getContent();

        model.addAttribute("currentPage",pageNo );
        model.addAttribute("totalPages",page.getTotalPages());
        model.addAttribute("totalItems",page.getTotalElements() );

        model.addAttribute("sortField",sortField );
        model.addAttribute("sortDir",sortDir );
        model.addAttribute("startDate",startDate);
        model.addAttribute("endDate",endDate);
        model.addAttribute("reverseSortDir",sortDir.equals("asc")?"desc":"asc");


        model.addAttribute("lightsList",lightsList );

        return "sensorsPages/lights";

    }

在我从查询删除 LIMIT 99999 后,我没有再收到错误消息,但是得到了这个并且它不起作用:

2021-03-05 16:09:47.789 DEBUG 3540 --- [nio-8080-exec-7] org.hibernate.sql                        : select * from lights Where timestamp BETWEEN ? AND ? ORDER BY id,id desc limit ?
2021-03-05 16:09:47.789 TRACE 3540 --- [nio-8080-exec-7] o.h.type.descriptor.sql.BasicBinder      : binding parameter [1] as [VARCHAR] - ['2021-03-04 15:27:07']
2021-03-05 16:09:47.789 TRACE 3540 --- [nio-8080-exec-7] o.h.type.descriptor.sql.BasicBinder      : binding parameter [2] as [VARCHAR] - ['2999-12-31 23:59:59']

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?