Screw 整合Oracle 报错异常信息oracle.jdbc.driver.T4CConnection.isValid(I)Z
今天整合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相关推荐
- 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 ...
- Linux/Centos 安装oracle报错“调用makefile '/oracle/produc
解决centos7/redhat7安装oracle11g到%70报错问题 Linux/Centos 安装oracle报错"调用makefile '/oracle/product/11.2.0 ...
- python连接oracle报错tns_Python3操作oracle数据库及遇到的报错
首先下载及安装cx_Oracle: 下载地址:http://www.lfd.uci.edu/~gohlke/pythonlibs/ 安装:pip3.6 install E:\Python36\Scri ...
- oracle 12514 pl sql,plsql登陆oracle报错!连接Oracle 10g时ORA-12514: TNS: 监听进程不能解析在连接描述符中给出的...
plsql登陆oracle出错!连接Oracle 10g时ORA-12514: TNS: 监听进程不能解析在连接描述符中给出的. 我添加了 (SID_DESC = (GLOBAL_DBNAME = ...
- ssis连接oracle报错,SSIS 连接Oracle报错 These components are supplied by Oracle
早上有个朋友发邮件给遇到一个SSIS连接Oracle的问题,具体的错误信息如下: Test connection failed because of an error in initializing ...
- oracle 报错ins 32008,oracle升级报错ins—32027
匿名用户 1级 2015-12-18 回答 [WARNING] [INS-32008] Oracle base location cant be same as the user home direc ...
- oracle报错数据复数,Oracle数据库设计策略及规范
Oracle数据库设计策略及规范 设计策略及规范 1. 目的 定义Oracle数据库设计规范,作为数据库规划.设计.开发以及维护人员的技术参考资料.用以规范和指导相关人员的设计行为. 2. 概述 本文 ...
- 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 ...
- oracle 报错pls 00405,oracle - 检查是否存在PLS-00405:在此上下文中不允许子查询 - 堆栈内存溢出...
使用正确的语法,将如下所示: create or replace procedure daily_rpt ( v_start in date , v_end in date ) as begin fo ...
- 为什么链接oracle报错,PG连接Oracle报错解决
epoll_wait(3, [{EPOLLIN, {u32=41936840, u64=41936840}}], 1, -1) = 1 recvfrom(10, "Q\0\0\0\26sel ...
最新文章
- poj 1283(递推ordp)
- 三十一、Python读写docx文件
- AliSQL开源Sequence Engine
- getBoundingClientRect说明
- LeetCode 232. Implement Queue using Stacks
- 知乎:“我们不主动收集数据”;滴滴被打乘客怂了;三星太子归位 | CSDN极客头条...
- 忘记 Apple Watch PIN 码,如何解锁 Apple Watch?
- LOJ 6278 数列分块入门2
- rfid sim卡 android,手机专用SIM卡的非接触移动支付技术标准之争:NFC vs RFID
- mac-数据库建模工具Workbench、PDMan
- C语言编程练习题_02兰州烧饼
- PHP代码审计工具——rips
- 何沐妮成为FILA高尔夫形象大使
- 计算机科学计数法符号,科学计数法怎么表示
- 聚苯乙烯/超高分子量聚乙烯合金包覆多孔SiO复合微球/聚苯乙烯微球载金属卟啉的研究
- 万维网互联网计算机网络的区别,姜多多:万维网,互联网与因特网有什么区别?...
- 社区专家谈12306
- 思维之道:管理何必那么虚
- openlayers标注面要素
- 宠物 java_java宠物练习
热门文章
- TM1620中显存地址是偶数
- 卡尔曼滤波系列——(二)扩展卡尔曼滤波
- matlab电流测量接法,matlab电压电流测量模块的使用
- Ubuntu20.04 libcef笔记
- spark数据查询语句select_Spark学习之Spark SQL
- 如何使用VMware 和ISO镜像文件 安装linux虚拟机,(附有安装工具)
- python程序输入两个整数、实现加减乘除_加减乘除
- 青年志愿者演讲稿合集15篇
- 逻辑英语语法电子版_11920671英语逻辑语法上.pdf
- 计算机固态硬盘作用,固态硬盘是什么及作用