当前位置: 首页 > news >正文

处理排序失败: net.sf.jsqlparser.JSQLParserException,降级为直接拼接 order by 参数

一、描述我的问题:

       在通过人员名字进行高级查询时,报错查询列表失败,查看日志发现sql中有两个order by 排序,本地启动代码console捕获异常为处理排序失败,降级为直接排序拼接 order by 参数。如下图

(可以理解为将java代码中写的排序和mapper.xml中sql中的order by 拼接到了一起)

17:47:20.743 [https-jsse-nio-8080-exec-9] WARN  c.g.p.p.OrderByParser - [converToOrderBySql,70] - 处理排序失败: net.sf.jsqlparser.JSQLParserException: net.sf.jsqlparser.parser.ParseException: Encountered unexpected token: "," ","at line 1, column 16.Was expecting one of:"&""::"";""<<"">>""COLLATE""CONNECT""EMIT""GROUP""HAVING""INTO""START""WINDOW""[""^""|"<EOF>
,降级为直接拼接 order by 参数

二、通过查询定位问题

因为sql中存在||导致的sql降级

三、解决方案

 1、最优解:通过cancat去进行拼接模糊查询

<if test="applicantName!=null and applicantName!=''">AND CONN.APPLICANT_NAME LIKE concat('%', #{applicantName}, '%')
</if>

2、将sql中的排序去掉

3、在java中将setOrderBy去除


http://www.mrgr.cn/news/10454.html

相关文章:

  • vue组件双向绑定
  • iOS WKWebView 禁止选中文字
  • 解决前端访问IIS服务器发生跨域请求报错的方法
  • 乾坤大挪移--将一个混乱的excel分类整理的辅助VBA代码
  • 基于Python的机器学习系列(10):朴素贝叶斯 - 多项式模型
  • 【机器学习】决策树------迅速了其基本思想,Sklearn的决策树API及构建决策树的步骤!!!
  • 低代码革命:JNPF平台如何简化企业应用开发
  • CSS实现鼠标hover展开菜单
  • 【Unity基础】Unity通信之SendMessage
  • 串口和RS485通信
  • 2024Android面试题与答案(1)
  • Shader 中的渲染顺序
  • 数学基础 -- 线性代数之增广矩阵
  • 快速排序与其例题
  • stm32智能颜色送餐小车(红外光管避障)
  • python如何调用另一个文件中的函数
  • 使用kafka改造分布式事务
  • 一文搞定MybatisPlus
  • asio之task_io_service多线程
  • [Linux]如何在虚拟机安装Ubuntu?(小白向)