解决ORA-12514,SQLPlus连接localhost:1521失败?

启动Oracle数据库服务

切换至Oracle用户

su - oracle  # 必须使用Oracle安装账户

启动监听器(Listener)

lsnrctl start  # 启动监听服务
lsnrctl status # 验证状态(显示"STATUS=READY"即成功)

启动数据库实例

sqlplus / as sysdba  # 以DBA身份登录SQL*Plus
SQL> STARTUP;        # 启动数据库实例
SQL> SELECT status FROM v$instance;  # 验证状态(返回"OPEN"即成功)

设置开机自启(可选)

sudo systemctl enable oracle-rdbms.service  # 适用于配置了Systemd的系统

连接Oracle数据库的常用方法

*命令行工具(SQLPlus)**

sqlplus username/password@hostname:port/service_name```
#### 2. **图形化工具(推荐)**
- **Oracle SQL Developer**  
  下载地址:[Oracle官网](https://www.oracle.com/database/sqldeveloper/)  
  配置步骤:  
  1. 输入主机名、端口(默认1521)、服务名(如ORCLCDB)  
  2. 填写用户名/密码  
  3. 测试连接 → 保存
- **DBeaver**  
  开源工具,支持多数据库([官网下载](https://dbeaver.io/))
#### 3. **通过Python脚本连接**
```python
import cx_Oracle
conn = cx_Oracle.connect('user', 'password', 'host:port/service_name')
cursor = conn.cursor()
cursor.execute("SELECT * FROM dual")
print(cursor.fetchone())

常见问题解决

监听器启动失败

  • 原因:端口冲突或配置错误
  • 解决
    lsnrctl stop          # 停止监听
    vi $ORACLE_HOME/network/admin/listener.ora  # 检查端口(默认1521)
    lsnrctl start         # 重新启动

数据库无法OPEN

  • 错误ORA-01081: cannot start already-running instance
    SQL> SHUTDOWN IMMEDIATE;  # 先关闭实例
    SQL> STARTUP;             # 重新启动
  • 错误ORA-01157: cannot identify/lock data file
    检查数据文件路径:

    SQL> SELECT name FROM v$datafile;  # 验证文件是否存在

连接超时

  • 检查防火墙:
    sudo firewall-cmd --list-ports | grep 1521  # 查看端口开放
    sudo firewall-cmd --add-port=1521/tcp --permanent  # 开放端口
  • 验证服务名:
    tnsping ORCLCDB  # 测试服务名解析

安全注意事项

  1. 最小权限原则:避免使用sysdba执行常规操作。
  2. 定期备份
    RMAN> BACKUP DATABASE PLUS ARCHIVELOG;  # 使用RMAN工具
  3. 更新补丁:定期安装Oracle Critical Patch Updates(CPU)。

引用说明

  • Oracle官方文档:Database Administrator’s Guide
  • Linux服务管理:Systemd手册
  • 连接工具参考:SQL Developer教程

重要提示:操作前确保已正确安装Oracle数据库(包括环境变量ORACLE_HOMEPATH配置),生产环境建议由专业DBA执行关键操作。

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

(0)
酷番叔酷番叔
上一篇 2025年6月17日 13:44
下一篇 2025年6月17日 14:08

相关推荐

  • 如何删除小写m并备份文件?

    在Linux系统中去除字符 m 的操作需根据具体场景选择合适方法,以下是专业且安全的实践指南:删除文件内容中的 m 字符方法1:使用 sed 流编辑器(推荐)# 删除所有大写 M(保留大小写敏感性)sed -i 's/M//g' filename.txt# 同时删除大小写 msed -i &#3……

    2025年6月15日
    1600
  • 如何高效使用 ip 命令?

    在Linux系统中查看内网IP地址是网络配置和故障排查的基础操作,内网IP(通常指私有IP地址,如x.x.x、16.x.x-172.31.x.x、168.x.x)用于局域网内设备通信,以下是6种专业方法,适用于大多数Linux发行版(Ubuntu、CentOS、Debian等),按使用频率排序:最现代且全面的工……

    1小时前
    100
  • 修改前必须做哪些准备?

    在Linux系统中,内核引导参数是控制操作系统启动行为的关键配置项,它们用于调整硬件兼容性(如解决显卡驱动问题)、启用特定功能(如调试模式)、优化性能(如设置CPU调度策略)或修复启动故障,修改内核参数属于高级操作,错误修改可能导致系统无法启动,操作前务必备份重要数据,并谨慎执行每一步,查看当前引导参数系统启动……

    5天前
    800
  • Linux如何保存网页到本地文件?

    图形界面操作(推荐普通用户)方法1:浏览器直接保存打开浏览器(如Firefox/Chrome)访问目标网页(https://example.com),右键菜单保存在页面空白处右键 → 选择 “另存为”(Firefox)或 “另存为…”(Chrome),或按快捷键 Ctrl+S(通用快捷键),选择保存格式完整……

    2025年7月7日
    900
  • 为什么越努力越焦虑?

    在Linux系统中,GCC(GNU Compiler Collection)是核心开发工具链之一,支持C、C++、Fortran等多种语言的编译,以下为详细使用指南,内容符合专业性与实用性标准,操作均基于主流Linux发行版(如Ubuntu、CentOS),安装GCC检查现有版本gcc –version……

    2025年6月22日
    1200

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信