Jboss7.4中使用SQLJ报错must be run under Oracle JDBC 9.0.0 or higher

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

工程使用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 initConnectionContex
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值