Screw 整合Oracle 报错异常信息oracle.jdbc.driver.T4CConnection.isValid(I)Z
Posted 在奋斗的大道
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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 {
@Test
public 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的主要内容,如果未能解决你的问题,请参考以下文章