Java中以Maven方式引入Oracle JDBC Driver依赖的详解

在Java开发中,使用Maven来管理项目依赖是一种非常常见且方便的方式。然而,对于Oracle JDBC Driver的依赖管理却稍显特殊,因为Oracle并没有将其JDBC Driver发布到公开的Maven仓库中。本文将详细介绍如何通过手动安装到本地仓库以及使用<scope>system</scope>的方式来引入Oracle JDBC Driver依赖,并探讨在SpringBoot项目中可能遇到的坑及其解决方法。

前言

由于Oracle JDBC Driver并未公开发布到Maven中央仓库,我们无法像引入MySQL、SQLite等数据库驱动那样直接通过Maven加载依赖。因此,我们需要手动下载Oracle JDBC Driver的Jar包,并将其安装到本地Maven仓库(.m2目录或自定义的localRepository)中,或者通过<scope>system</scope>的方式引入。

手动安装到本地仓库
  1. 下载Oracle JDBC Driver Jar包

    首先,我们需要从Oracle官网下载所需的JDBC Driver Jar包,例如ojdbc7-12.1.0.2.jar

  2. 将Jar包放置到项目目录中

    将下载的ojdbc7-12.1.0.2.jar放置到项目的根目录下的lib目录中,以便随项目进行版本管理。

  3. 在POM.xml中加入依赖定义

    在项目的POM.xml文件中加入以下依赖定义(但暂时不指定具体路径,因为接下来我们会通过命令行安装):

    xml 复制代码
    <dependency>
        <groupId>com.oracle</groupId>
        <artifactId>ojdbc7</artifactId>
        <version>12.1.0.2</version>
    </dependency>

    注意:这里的<groupId><artifactId>可以根据实际情况自定义。

  4. 安装JAR包到本地仓库

    使用以下Maven命令将Jar包安装到本地仓库:

    bash 复制代码
    mvn install:install-file -Dfile=lib/ojdbc7-12.1.0.2.jar -DgroupId=com.oracle -DartifactId=ojdbc7 -Dversion=12.1.0.2 -Dpackaging=jar

    执行上述命令后,Oracle JDBC Driver将被安装到本地Maven仓库中,之后Maven在构建项目时就能够找到这个依赖。

使用<scope>system</scope>方式引入

除了手动安装到本地仓库外,我们还可以在POM.xml中将依赖定义为<scope>system</scope>。这种方式下,即使本地仓库(.m2目录)下没有Oracle JDBC Driver依赖,执行mvn compilemvn spring-boot:run依然能够成功执行。

示例代码

xml 复制代码
<dependency>
    <groupId>com.oracle</groupId>
    <artifactId>ojdbc7</artifactId>
    <version>12.1.0.2</version>
    <scope>system</scope>
    <systemPath>${project.basedir}/lib/ojdbc7-12.1.0.2.jar</systemPath>
</dependency>

注意<systemPath>需要指定为Jar包的绝对路径或相对于项目的路径。

<scope>system</scope>在SpringBoot中的坑

虽然使用<scope>system</scope>可以方便地在开发环境中运行SpringBoot应用,但在执行mvn package打包时,生成的SpringBoot UberJar包中并不会包含Oracle JDBC Driver依赖。直接部署到服务器上会报错,如:

复制代码
############ application failed to start
Description: .................................. 
Reason: Failed to load driver class oracle.jdbc.driver.OracleDriver in either of HikariConfig class loader or Thread context classloader.
Action: Update your application's configuration ############

解决方法

  • 对于外置Web容器的SpringBoot应用,将Oracle JDBC Driver Jar包放置在容器的lib目录下。

  • 对于内置Web容器的SpringBoot应用,修改spring-boot-maven-plugin插件配置:

    xml 复制代码
    <build>
      <plugins>
        <plugin>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-maven-plugin</artifactId>
          <configuration>
            <includeSystemScope>true</includeSystemScope>
          </configuration>
        </plugin>
      </plugins>
    </build>

    通过配置<includeSystemScope>true</includeSystemScope>,可以使得scopesystem的Jar包也被打包到最终的发布包中。

Maven依赖定义中的scope属性

scope属性用于限制依赖在Maven项目各生命周期的作用范围。常见的scope值有:

  • compile:默认值,依赖将参与编译阶段,并会被打包到最终发布包(如Jar、War、UberJar)内的Lib目录下。具有传递性。
  • provided:依赖将参与编译阶段但不会被打包到最终的发布包,运行阶段由容器或JDK提供。不具备传递性。
  • runtime:依赖不参与编译阶段(即不加入到classpath),但会打包到最终发布包,从而参与运行和测试阶段。
  • test:依赖参加编译阶段,但不打包到最终发布包,依赖仅参与测试阶段。
  • system :表示该依赖项的路径为基于文件系统的Jar包路径,并且必须通过systemPath指定本地文件路径。依赖参与编译阶段,默认不会被打包到最终发布包。
  • import (仅能在<dependencyManagement>中使用):用于引用其它项目的依赖项。

示例

xml 复制代码
<!-- 引入项目io.fsjohnhuang.deps的依赖项 -->
<dependencyManagement>
  <dependency>
    <groupId>io.fsjohnhuang</groupId>
    <artifactId>deps</artifactId>
    <type>pom</type>
    <scope>import</scope>
  </dependency>
</dependencyManagement>

关于type属性,默认的type属性值为jar,即Maven将项目编译打包为Jar包。当设置为pom时,表示该项目为一堆相关依赖项的打包定义。当设置为apkejb等时,表示Maven在编译打包时采用相应的插件执行任务。

相关推荐
C4程序员1 小时前
Java百度身份证识别接口实现【配置即用】
java·开发语言
炒空心菜菜1 小时前
MapReduce 实现 WordCount
java·开发语言·ide·后端·spark·eclipse·mapreduce
zy happy1 小时前
搭建运行若依微服务版本ruoyi-cloud最新教程
java·spring boot·spring cloud·微服务·ruoyi
芯眼2 小时前
STM32启动文件详解(重点)
java·开发语言·c++·stm32·单片机·mybatis
zxrhhm2 小时前
Oracle 中的虚拟列Virtual Columns和PostgreSQL Generated Columns生成列
postgresql·oracle·vr
想躺平的小农2 小时前
EasyExcel详解
java
慧一居士2 小时前
EasyExcel集成使用总结与完整示例
java·excel
呦呦彬2 小时前
【问题排查】easyexcel日志打印Empty row!
java·开发语言·log4j
九章云极AladdinEdu3 小时前
GPU与NPU异构计算任务划分算法研究:基于强化学习的Transformer负载均衡实践
java·开发语言·人工智能·深度学习·测试工具·负载均衡·transformer
佩奇的技术笔记3 小时前
Java学习手册:客户端负载均衡
java·负载均衡