com.alibaba.druid.sql.parser.ParserException: TODO pos 2040, line 44, column 46, token RPAREN

背景

在环境中报如下错误,但是并没有影响业务的执行,业务还是正常的执行的

com.alibaba.druid.sql.parse.ParserException: TODO pos 2040, line 44, colunm 46, token RPAREN
  • druid 版本: druid-1.1.22
  • 数据库: postgresql

报错sql

select u.name,ud.adress
from user as u,user_detail as ud
where ud.uid=u.id(+)

以上sql已经经过处理了,简单化了

源码分析

StatFilter


public String mergeSql(String sql, String dbType) {
        if (!mergeSql) {
            return sql;
        }

        try {
            sql = ParameterizedOutputVisitorUtils.parameterize(sql, dbType);
        } catch (Exception e) {
            LOG.error("merge sql error, dbType " + dbType + ", druid-" + VERSION.getVersionNumber() + ", sql : " + sql, e);
        }

        return sql;
    }

SQLExprParser

image

上面代码发现 +的后面解析不了右括号,所以报错,看看高版本是否支持。

druid 版本:1.2.11 问题还没有修复

解决方案

image

# 之前这个是true,现在改成false
druid.stat.mergeSql=false
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值