今天整合Screw(螺丝钉) 和Oracle 生成数据库文档时,提示如下错误信息:oracle.jdbc.driver.T4CConnection.isValid(I)Z

完整 控制台输出错误信息:

2021-05-13 09:23:23 [main] INFO  com.zaxxer.hikari.HikariDataSource -HikariPool-1 - Starting...
2021-05-13 09:23:23 [main] INFO  com.zaxxer.hikari.pool.PoolBase -HikariPool-1 - Driver does not support get/set network timeout for connections. (oracle.jdbc.driver.T4CConnection.getNetworkTimeout()I)
2021-05-13 09:23:23 [main] ERROR com.zaxxer.hikari.pool.PoolBase -HikariPool-1 - Failed to execute isValid() for connection, configure connection test query (oracle.jdbc.driver.T4CConnection.isValid(I)Z).

问题排查:

1、检查Oracle 版本

执行如下指令:select * from v$version;

2、 检查Java 版本

执行如下指令:java -version

3、 查询Oracle 驱动 与JDK 版本对应关系(网上可以google 或者baidu,这是我从网上摘抄部分对应关系)

Oracle Database version JDBC Jar files specific to the release
18.3 ojdbc8.jar with JDK8, JDK9, JDK10, JDK11
12.2 or 12cR2 ojdbc8.jar with JDK 8
12.1 or 12cR1 ojdbc7.jar with JDK 7 and JDK 8 ojdbc6.jar with JDK 6
11.2 or 11gR2 ojdbc6.jar with JDK 6, JDK 7, and JDK 8 (Note: JDK7 and JDK8 are supported in 11.2.0.3 and 11.2.0.4 only) ojdbc5.jar with JDK 5

注意红色字体:针对oracle 11g 版本且JDK8 版本,指定的特定版本是ojdbc6-11.2.0.4

4、 pom 文件调整

4.1 我首先加载的oracle 驱动版本为:ojdbc6-11.2.0.3 ,pom.xml 文件如下:

 <!-- 数据库文档自动生成 --><dependency><groupId>cn.smallbun.screw</groupId><artifactId>screw-core</artifactId><version>1.0.5</version></dependency><!-- Oracle --><dependency><groupId>com.oracle</groupId><artifactId>ojdbc6 </artifactId><version>11.2.0.3</version></dependency>

继续指定数据库文档生成,还是提示上述错误。

4.2 我尝试寻找ojdbc-11.2.0.4 驱动,但是在网上没有检索到相关资源,我查看对应关系ojdbc8 支持jdk 8 版本,我就下载了一个ojdbc8-12.2.0.1 驱动包,加载至pom.xml 文件中

<!-- 数据库文档自动生成 --><dependency><groupId>cn.smallbun.screw</groupId><artifactId>screw-core</artifactId><version>1.0.5</version></dependency><!-- Oracle --><dependency><groupId>com.oracle</groupId><artifactId>ojdbc8 </artifactId><version>12.2.0.1</version></dependency>

继续执行数据库文档生成,成功

Screw+ Oracle 生成数据库文档核心功能代码:

package com.zzg.test;import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import javax.sql.DataSource;
import org.junit.Test;
import org.springframework.boot.test.context.SpringBootTest;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
import cn.smallbun.screw.core.Configuration;
import cn.smallbun.screw.core.engine.EngineConfig;
import cn.smallbun.screw.core.engine.EngineFileType;
import cn.smallbun.screw.core.engine.EngineTemplateType;
import cn.smallbun.screw.core.execute.DocumentationExecute;
import cn.smallbun.screw.core.process.ProcessConfig;@SpringBootTest
public class ScrewApplicationTest {@Testpublic void screwGenerate() throws Exception {//数据源HikariConfig hikariConfig = new HikariConfig();// Oracle 数据库hikariConfig.setDriverClassName("oracle.jdbc.driver.OracleDriver");hikariConfig.setJdbcUrl("jdbc:oracle:thin:@127.0.0.1:1521:orcl");hikariConfig.setUsername("gx_test");hikariConfig.setPassword("gx_test");DataSource hikariDataSource = new HikariDataSource(hikariConfig);// 生成文件配置EngineConfig engineConfig = EngineConfig.builder()// 生成文件路径,自己mac本地的地址,这里需要自己更换下路径.fileOutputDir("D:\\doc")// 打开目录.openOutputDir(false)// 文件类型.fileType(EngineFileType.HTML)// 生成模板实现.produceType(EngineTemplateType.freemarker).build();// 生成文档配置(包含以下自定义版本号、描述等配置连接)Configuration config = Configuration.builder().version("1.0.0").description("生成文档信息描述").dataSource(hikariDataSource).engineConfig(engineConfig).produceConfig(getProcessConfig()).build();// 执行生成new DocumentationExecute(config).execute();}/*** 配置想要生成的表+ 配置想要忽略的表* * @return 生成表配置*/public static ProcessConfig getProcessConfig() {// 忽略表名List<String> ignoreTableName = Arrays.asList("aa", "test_group");// 忽略表前缀,如忽略a开头的数据库表List<String> ignorePrefix = Arrays.asList("a", "t");// 忽略表后缀List<String> ignoreSuffix = Arrays.asList("_test", "czb_");return ProcessConfig.builder()// 根据名称指定表生成.designatedTableName(new ArrayList<>())// 根据表前缀生成.designatedTablePrefix(new ArrayList<>())// 根据表后缀生成.designatedTableSuffix(new ArrayList<>())// 忽略表名.ignoreTableName(new ArrayList<>())// 忽略表前缀.ignoreTablePrefix(new ArrayList<>())// 忽略表后缀.ignoreTableSuffix(new ArrayList<>()).build();}
}

Screw 整合Oracle 报错异常信息oracle.jdbc.driver.T4CConnection.isValid(I)Z相关推荐

  1. JSP Tomcat8.0运行连接池时发生异常【AbstractMethodError oracle.jdbc.driver.T4CConnection.isValid(I)Z】...

    原创 2015年12月28日 11:38:01 2004 一.Tomcat8.0运行连接池时发生异常: AbstractMethodError oracle.jdbc.driver.T4CConnec ...

  2. Linux/Centos 安装oracle报错“调用makefile '/oracle/produc

    解决centos7/redhat7安装oracle11g到%70报错问题 Linux/Centos 安装oracle报错"调用makefile '/oracle/product/11.2.0 ...

  3. python连接oracle报错tns_Python3操作oracle数据库及遇到的报错

    首先下载及安装cx_Oracle: 下载地址:http://www.lfd.uci.edu/~gohlke/pythonlibs/ 安装:pip3.6 install E:\Python36\Scri ...

  4. oracle 12514 pl sql,plsql登陆oracle报错!连接Oracle 10g时ORA-12514: TNS: 监听进程不能解析在连接描述符中给出的...

    plsql登陆oracle出错!连接Oracle 10g时ORA-12514: TNS: 监听进程不能解析在连接描述符中给出的. 我添加了 (SID_DESC =  (GLOBAL_DBNAME =  ...

  5. ssis连接oracle报错,SSIS 连接Oracle报错 These components are supplied by Oracle

    早上有个朋友发邮件给遇到一个SSIS连接Oracle的问题,具体的错误信息如下: Test connection failed because of an error in initializing ...

  6. oracle 报错ins 32008,oracle升级报错ins—32027

    匿名用户 1级 2015-12-18 回答 [WARNING] [INS-32008] Oracle base location cant be same as the user home direc ...

  7. oracle报错数据复数,Oracle数据库设计策略及规范

    Oracle数据库设计策略及规范 设计策略及规范 1. 目的 定义Oracle数据库设计规范,作为数据库规划.设计.开发以及维护人员的技术参考资料.用以规范和指导相关人员的设计行为. 2. 概述 本文 ...

  8. centos安装oracle报错,CentOS安装oracle和rsh服务报错处理

    CentOS安装rsh服务rpm包时报错 CentOS安装rsh-0.17-14.i386.rpm和rsh-server-0.17-14.i386.rpm服务包时报错如下:warning: rsh-s ...

  9. oracle 报错pls 00405,oracle - 检查是否存在PLS-00405:在此上下文中不允许子查询 - 堆栈内存溢出...

    使用正确的语法,将如下所示: create or replace procedure daily_rpt ( v_start in date , v_end in date ) as begin fo ...

  10. 为什么链接oracle报错,PG连接Oracle报错解决

    epoll_wait(3, [{EPOLLIN, {u32=41936840, u64=41936840}}], 1, -1) = 1 recvfrom(10, "Q\0\0\0\26sel ...

最新文章

  1. poj 1283(递推ordp)
  2. 三十一、Python读写docx文件
  3. AliSQL开源Sequence Engine
  4. getBoundingClientRect说明
  5. LeetCode 232. Implement Queue using Stacks
  6. 知乎:“我们不主动收集数据”;滴滴被打乘客怂了;三星太子归位 | CSDN极客头条...
  7. 忘记 Apple Watch PIN 码,如何解锁 Apple Watch?
  8. LOJ 6278 数列分块入门2
  9. rfid sim卡 android,手机专用SIM卡的非接触移动支付技术标准之争:NFC vs RFID
  10. mac-数据库建模工具Workbench、PDMan
  11. C语言编程练习题_02兰州烧饼
  12. PHP代码审计工具——rips
  13. 何沐妮成为FILA高尔夫形象大使
  14. 计算机科学计数法符号,科学计数法怎么表示
  15. 聚苯乙烯/超高分子量聚乙烯合金包覆多孔SiO复合微球/聚苯乙烯微球载金属卟啉的研究
  16. 万维网互联网计算机网络的区别,姜多多:万维网,互联网与因特网有什么区别?...
  17. 社区专家谈12306
  18. 思维之道:管理何必那么虚
  19. openlayers标注面要素
  20. 宠物 java_java宠物练习

热门文章

  1. TM1620中显存地址是偶数
  2. 卡尔曼滤波系列——(二)扩展卡尔曼滤波
  3. matlab电流测量接法,matlab电压电流测量模块的使用
  4. Ubuntu20.04 libcef笔记
  5. spark数据查询语句select_Spark学习之Spark SQL
  6. 如何使用VMware 和ISO镜像文件 安装linux虚拟机,(附有安装工具)
  7. python程序输入两个整数、实现加减乘除_加减乘除
  8. 青年志愿者演讲稿合集15篇
  9. 逻辑英语语法电子版_11920671英语逻辑语法上.pdf
  10. 计算机固态硬盘作用,固态硬盘是什么及作用