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多张报表,全改一遍太浪费时间了啊,所以只能继续深入研究一下,看是否使用之前的低版本来解决那个开头的异常问题。毕竟极个别的异常,修改起来就比较简单。
但迫于项目上的压力,先暂时这么解决着吧,以后再遇到了其他问题再去解决。