工程使用Oracle19.3的sqlj.exe翻译,部署在Jboss7.4,使用Jboss的数据源访问数据库,启动工程报错
java.lang.IllegalArgumentException: SQLJ programs translated with the option -codegen=oracle must be run under Oracle JDBC 9.0.0 or higher. If the Oracle JDBC driver is wrapped, then the wrapper must implement all of the oracle.jdbc.OracleXxxx interfaces. Alternatively, you can translate SQLJ programs either with -codegen=iso.
从字面意思来看是JDBC驱动版本有问题,但把能想到的各种classpath都设置了还是报这个错误,觉得很奇怪,开始怀疑并不是我的JDBC驱动版本有问题而是连接数据库时出了其他错误刚好报了这么个错误信息。
于是反编译sqlj的运行时包runtime12.jar,直接看源码,不就知道具体咋回事了
//ConnectionContextImpl.java
public OracleConnection getOracleConnection() {
if (this.m_oconn == null) {
throw new IllegalArgumentException("SQLJ programs translated with the option -codegen=oracle must be run under Oracle JDBC 9.0.0 or higher. If the Oracle JDBC driver is wrapped, then the wrapper must implement all of the oracle.jdbc.OracleXxxx interfaces. Alternatively, you can translate SQLJ programs either with -codegen=iso.");
} else {
return this.m_oconn;
}
}
private void initConnectionContext

在Jboss7.4上部署的工程使用Oracle19.3 SQLJ翻译并借助Jboss数据源访问数据库时遇到报错。错误信息提示必须使用Oracle JDBC 9.0.0或更高版本。通过反编译sqlj的运行时包,发现错误并非由于JDBC驱动版本,而是与连接类型有关。问题最终由 WrappedConnectionJDK 转换为 OracleConnection 解决,通过反射执行特定方法,并排除冲突的ojdbc依赖,成功解决所有问题。
最低0.47元/天 解锁文章
1738

被折叠的 条评论
为什么被折叠?



