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 versionJDBC Jar files specific to the release
18.3ojdbc8.jar with JDK8, JDK9, JDK10, JDK11
12.2 or 12cR2ojdbc8.jar with JDK 8
12.1 or 12cR1ojdbc7.jar with JDK 7 and JDK 8 ojdbc6.jar with JDK 6
11.2 or 11gR2ojdbc6.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();
	}
}

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值