SQLPlus连接Oracle数据库技巧

准备工作

  1. 安装Oracle客户端

    • 官方客户端选择

      • 完整客户端:适用于长期使用(官网下载)
      • Instant Client:轻量级方案(推荐基础包+SQL*Plus)
    • 安装步骤(以Instant Client为例):

      # 解压安装包
      unzip instantclient-basic-linux.x64-19.13.0.0.0dbru.zip -d /opt/oracle/
      unzip instantclient-sqlplus-linux.x64-19.13.0.0.0dbru.zip -d /opt/oracle/
      # 配置环境变量
      echo 'export ORACLE_HOME=/opt/oracle/instantclient_19_13' >> ~/.bashrc
      echo 'export LD_LIBRARY_PATH=$ORACLE_HOME:$LD_LIBRARY_PATH' >> ~/.bashrc
      echo 'export PATH=$ORACLE_HOME:$PATH' >> ~/.bashrc
      source ~/.bashrc
  2. 配置网络文件

    • 创建 tnsnames.ora(路径:$ORACLE_HOME/network/admin/):
      ORCL =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = oracle_server_ip)(PORT = 1521))
          (CONNECT_DATA =
            (SERVER = DEDICATED)
            (SERVICE_NAME = ORCL)
          )
        )

连接方式详解

*方法1:SQLPlus命令行**

sqlplus username/password@ORCL```
#### **方法2:Python脚本(cx_Oracle)**
1. 安装驱动:
   ```bash
   pip install cx_Oracle
  1. Python连接代码:
    import cx_Oracle
    dsn = cx_Oracle.makedsn("oracle_server_ip", 1521, service_name="ORCL")
    conn = cx_Oracle.connect(user="scott", password="tiger", dsn=dsn)
    cursor = conn.cursor()
    cursor.execute("SELECT * FROM emp")
    print(cursor.fetchall())
    conn.close()

方法3:JDBC连接(Java应用)

  1. 下载JDBC驱动:ojdbc8.jar
  2. Java示例:
    import java.sql.*;
    public class OracleConn {
      public static void main(String[] args) {
        String url = "jdbc:oracle:thin:@//oracle_server_ip:1521/ORCL";
        try (Connection conn = DriverManager.getConnection(url, "scott", "tiger")) {
          System.out.println("Connected to Oracle!");
        } catch (SQLException e) { e.printStackTrace(); }
      }
    }

故障排查与优化

  1. 常见错误解决

    • TNS-12541: No listener
      检查Oracle服务器监听状态:lsnrctl status
    • ORA-12170: TNS Connect timeout
      确认防火墙放行1521端口:sudo ufw allow 1521/tcp
    • 库文件缺失
      安装依赖:sudo apt-get install libaio1(Debian/Ubuntu)
  2. 性能优化建议

    • 启用连接池(如Oracle UCP或第三方工具)
    • 使用tnsping ORCL测试网络延迟
    • 定期清理INACTIVE会话

安全注意事项

  1. 敏感信息保护
    • 避免在脚本中硬编码密码(使用环境变量或密钥管理工具)
    • 配置文件权限:chmod 600 tnsnames.ora
  2. 加密连接
    • 强制使用TCPS协议
    • 配置Oracle Native Network Encryption

通过上述步骤,您可高效安全地在Linux环境中连接Oracle数据库,建议结合具体场景选择连接方式,并定期更新客户端版本以获取安全补丁,对于生产环境,务必遵循最小权限原则和审计要求。

引用说明

  • Oracle Instant Client 官方文档:Oracle Help Center
  • cx_Oracle 使用指南:GitHub – oracle/python-cx_Oracle
  • JDBC 配置参考:Oracle JDBC Developer’s Guide 基于Oracle 19c及Linux主流发行版验证,适用于CentOS 7+/Ubuntu 20.04+环境。*

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

(0)
酷番叔酷番叔
上一篇 2025年7月12日 01:24
下一篇 2025年7月12日 01:35

相关推荐

  • Linux如何成为root用户?权限切换与获取方法解析

    Linux作为多用户多任务操作系统,root用户拥有系统的最高管理权限,可执行所有命令、访问所有文件、管理用户及系统配置,日常操作中,安装软件、修改系统核心配置、管理磁盘分区等任务常需root权限,掌握正确的root权限获取方式对系统管理和安全至关重要,以下是Linux系统中成为root用户的常用方法及注意事项……

    2025年8月26日
    3500
  • 如何在虚拟机中用Linux高效下载?

    在虚拟机软件中安装Linux系统,配置网络连接后,使用系统自带或安装的下载工具(如wget、curl或图形化下载器)进行文件下载,注意管理虚拟磁盘空间。

    2025年7月30日
    4600
  • Linux系统安装中文语言包及输入法显示设置的完整步骤是什么?

    在Linux系统中安装中文支持涉及语言环境配置、输入法安装、字体设置等多个环节,不同发行版的具体操作略有差异,但核心逻辑一致,以下以主流的Ubuntu/Debian和CentOS/RHEL为例,详细说明完整流程,系统语言环境配置Linux系统的语言环境由locale控制,需确保系统支持中文语言包(如zh_CN……

    2025年9月24日
    1600
  • 如何清除Linux系统的缓存文件夹?

    Linux系统中的缓存是为了提升系统性能而设计的,通过将频繁访问的数据暂存到内存中,减少磁盘I/O操作,从而加快程序响应速度,但长时间运行后,缓存文件可能会占用大量磁盘空间,导致系统变慢或存储不足,此时需要手动清除缓存,清除缓存需区分系统级缓存和应用级缓存,不同类型缓存的清除方式有所不同,操作时需注意权限和数据……

    2025年9月20日
    2400
  • 如何查看网卡enp0s3驱动?

    核心命令行工具lsmod:查看已加载的驱动模块命令:lsmod输出示例:Module Size Used bynvidia 35323904 203iwlmvm 495616 0…解读:Module:驱动名称(如 nvidia 为显卡驱动),Used by:依赖该模块的进程或模块数量,lspci:查看PCI……

    2025年8月3日
    3200

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信