处理排序失败: 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去除

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@百思不得奇解

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值