关于使用druid高低版本遇到的问题

1.背景

目前项目上需要用到动态数据源,支持mysql和oracle数据库的查询。之前使用的版本为1.1.2,执行极个别特定的SQL时,抛出了如下异常

获取字段列表异常:java.lang.ClassCastException: com.alibaba.druid.sql.visitor.SchemaStatVisitor$OracleOrderByStatVisitor cannot be cast to com.alibaba.druid.sql.dialect.oracle.visitor.OracleASTVisitor

无奈度娘搜一波呗,自信满满以为很快就解决了,想不到一下就陷进去了。

2.解决之旅

虽然网上搜了这个异常无结果,但看到了一些关于druid存在的bug的文章,意思就是低版本可能会存在一些莫名其妙的问题,而且查不到原因之类的,只能通过升级版本来解决问题。迫于无奈,将版本升级为1.2.11,然后修改了一些不兼容的代码后,上面异常的代码没有出现了。

没高兴太久,第二天就发现了新的异常

获取字段列表异常:java.lang.ClassCastException: com.alibaba.druid.sql.ast.statement.SQLUnionQuery cannot be cast to com.alibaba.druid.sql.dialect.oracle.ast.stmt.OracleSelectQueryBlock

导致这个异常的SQL如下

select '1' id,'门诊' name from dual
union all
select '2' id,'住院' name from dual

然后根据异常信息,研究一番后,修改为以下SQL就不会异常了

select id,name from (
select '1' id,'门诊' name from dual
union all
select '2' id,'住院' name from dual
)

奇奇怪怪的知识又增加了。但是我们现场有已经配置好了的100多张报表,全改一遍太浪费时间了啊,所以只能继续深入研究一下,看是否使用之前的低版本来解决那个开头的异常问题。毕竟极个别的异常,修改起来就比较简单。

但迫于项目上的压力,先暂时这么解决着吧,以后再遇到了其他问题再去解决。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值