Linux环境下Java如何连接Oracle数据库?

在Linux环境下,Java程序连接Oracle数据库是企业级开发中的常见需求,需完成环境准备、驱动配置、代码编写及问题排查等步骤,下面详细介绍具体流程。

linux java如何连接oracle

环境准备

首先需确保Linux系统、Java开发环境及Oracle数据库正常运行,推荐使用CentOS 7+或Ubuntu 18.04+系统,安装JDK 1.8/11/17(需与Oracle JDBC驱动版本匹配),并确认Oracle数据库(11g/12c/19c/21c)已启动监听服务,可通过命令检查:

  • 查看JDK版本:java -version
  • 检查Oracle监听状态:lsnrctl status,若未启动则执行lsnrctl start

JDBC驱动配置

Oracle JDBC驱动是Java连接数据库的核心组件,需根据数据库版本和JDK版本选择对应驱动(如ojdbc8.jar、ojdbc11.jar),可通过Oracle官网下载,或使用Maven/Gradle管理依赖。

Maven依赖配置(以ojdbc8为例):

<dependency>
    <groupId>com.oracle.database.jdbc</groupId>
    <artifactId>ojdbc8</artifactId>
    <version>19.3.0.0</version> <!-- 需匹配Oracle数据库版本 -->
</dependency>

若为非Maven项目,需手动下载驱动jar包,并将其置于项目lib目录,编译时通过-cp参数指定路径:

linux java如何连接oracle

javac -cp ./lib/ojdbc8.jar:. YourClass.java

Java代码实现

连接Oracle的核心步骤包括加载驱动、获取连接、执行SQL及释放资源,以下为完整示例代码:

import java.sql.*;
public class OracleConnTest {
    public static void main(String[] args) {
        // 连接字符串格式:jdbc:oracle:thin:@//主机:端口/服务名
        String url = "jdbc:oracle:thin:@//192.168.1.100:1521/orcl";
        String user = "scott";
        String password = "tiger";
        try (Connection conn = DriverManager.getConnection(url, user, password);
             Statement stmt = conn.createStatement();
             ResultSet rs = stmt.executeQuery("SELECT * FROM emp WHERE rownum <= 5")) {
            System.out.println("EMPNOtENAME");
            while (rs.next()) {
                System.out.println(rs.getInt("EMPNO") + "t" + rs.getString("ENAME"));
            }
        } catch (SQLException e) {
            System.err.println("连接失败: " + e.getMessage());
            e.printStackTrace();
        }
    }
}

说明

  • 连接字符串中表示TCP直连,避免依赖本地tnsnames.ora文件;
  • 使用try-with-resources自动关闭ConnectionStatementResultSet,防止资源泄漏;
  • 服务名(Service Name)和SID(系统标识符)需根据Oracle数据库配置选择,可通过sqlplus / as sysdba执行SELECT instance_name FROM v$instance查看SID,或SELECT value FROM v$parameter WHERE name = 'service_names'查看服务名。

常见问题排查

  1. ClassNotFoundException:驱动jar包未加入classpath,或Maven依赖未下载成功,检查项目lib目录是否存在驱动jar,或执行mvn clean install更新依赖。
  2. IO异常:Network Adapter unable to establish connection
    • 检查防火墙是否开放1521端口(firewall-cmd --list-ports确认);
    • 确认Oracle监听是否启动(lsnrctl status),若未启动则执行lsnrctl start
    • 验证主机名/IP是否正确,可通过telnet 目标IP 1521测试网络连通性。
  3. ORA-01017: invalid username/password:确认数据库用户名、密码是否正确,以及用户是否有远程连接权限(GRANT CONNECT TO scott)。

Oracle数据库版本与JDBC驱动对应表

Oracle数据库版本 推荐JDBC驱动版本 适用JDK版本
11g R2 ojdbc6.jar/ojdbc8.jar 6/1.8
12c R1/R2 ojdbc8.jar 8+
19c/21c ojdbc11.jar 11+

连接字符串格式示例

场景 连接字符串格式 说明
使用服务名(推荐) jdbc:oracle:thin:@//主机:端口/服务名 适用于Oracle 10g及以上,无需本地配置
使用SID jdbc:oracle:thin:@主机:端口:SID 适用于旧版Oracle(如9i)

FAQs

Q1: Linux下连接Oracle时提示“ORA-12514: TNS:监听程序当前无法识别连接描述符中请求的服务”,如何解决?
A: 该错误通常因服务名/SID配置错误或监听未注册服务导致,检查tnsnames.ora文件中的服务名是否与数据库实例名一致,或执行lsnrctl services查看监听器注册的服务列表,若使用动态注册(默认),确保数据库实例已启动(sqlplus / as sysdba执行startup)。

linux java如何连接oracle

Q2: Java程序在Linux服务器上运行正常,但在其他Linux服务器上连接Oracle超时,可能的原因是什么?
A: 可能原因包括:(1)目标服务器防火墙未开放1521端口,需执行firewall-cmd --add-port=1521/tcp --permanent并重载;(2)网络路由问题,使用traceroute 目标IP检查网络路径;(3)Oracle监听绑定IP为127.0.0.1,需修改$ORACLE_HOME/network/admin/listener.ora,将HOST = localhost改为HOST = 0.0.0.0并重启监听。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/32818.html

(0)
酷番叔酷番叔
上一篇 2025年9月30日 01:23
下一篇 2025年9月30日 01:46

相关推荐

  • lr如何实现对Linux系统资源的监控?

    lr工具是一款基于Linux系统开发的轻量级资源监控脚本,通过整合系统原生命令(如top、vmstat、iostat、free等)实现自动化数据采集与可视化分析,适用于服务器资源状态巡检、性能瓶颈定位及历史趋势追踪,以下从核心资源维度详细说明lr工具的监控方法,CPU资源监控CPU是系统核心资源,lr工具通过多……

    2025年9月20日
    2100
  • Linux改root密码如何避免风险?

    当前用户拥有sudo权限(推荐)适用场景:已知普通用户密码且该用户已被加入sudo组(如Ubuntu默认配置),步骤:打开终端,执行命令: sudo passwd root输入当前用户的登录密码(验证sudo权限),输入两次新的root密码(输入时无星号提示,属正常现象),出现 passwd: password……

    2025年7月23日
    4200
  • Linux死锁如何预防检测恢复?

    死锁的成因死锁需同时满足四个条件:互斥:资源独占(如锁被一个进程持有),持有并等待:进程持有资源的同时请求新资源,不可抢占:资源只能由持有者主动释放,循环等待:多个进程形成资源请求的环形依赖,死锁预防(编程层)通过破坏死锁条件避免发生:锁顺序规则所有线程按全局固定顺序获取锁(如先锁A再锁B),破坏循环等待,示例……

    2025年7月4日
    5200
  • acer电脑Linux系统开机如何进入BIOS设置?

    在Linux系统中使用Acer电脑时,若需进入BIOS(基本输入输出系统)进行硬件设置、启动顺序调整或开启虚拟化等功能,可通过以下多种方法实现,具体操作需结合电脑型号和启动模式(Legacy BIOS或UEFI)灵活调整,常规开机进入法(最常用)Acer电脑多数支持在开机瞬间通过特定按键强制进入BIOS,这是最……

    2025年9月27日
    1700
  • cron限制导致任务失败?

    在Linux系统中,定时任务(计划任务)是自动化运维的核心功能,可帮助用户定期执行脚本、备份数据或维护系统,以下为详细设置方法,基于cron和at两大工具,遵循Linux通用标准(如Systemd和SysVinit环境),确保安全性与可操作性,核心工具:cron 设置周期性任务编辑用户级定时任务crontab……

    2025年7月28日
    4300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信