news 2026/6/13 12:13:30

遇到一个ORA-01017错误,解决方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
遇到一个ORA-01017错误,解决方法

访问https://www.tomcoding.com网站,学习Oracle内部数据结构,详细文档说明,下载Oracle的exp/imp,DUL,logminer,ASM工具的源代码,学习高技术含量的内容。

ORA-01017 “invalid username/password; logon denied” 是 Oracle 数据库操作中碰壁最多、原因却最隐蔽的认证错误之一。很多时候明明用户名密码一字不差,客户端依然反复弹出这个提示,问题往往出在密码文件、参数策略或账户状态上。下面这篇实战梳理,会把常见的“坑”一网打尽。

如果刚遇到这个问题,先不要动参数、不要重建文件,按这五步快速过一遍,往往就已经能解决。

1. 密码错了
在 SQL*Plus 里用最原始的方式验证一次:sqlplus 用户名/密码@连接串。彻底排除客户端工具自带的空格、换行、全角字符、大小写转换隐藏的干扰。
如果能够登录,说明问题出在应用程序的连接串或 IDE 的凭据缓存,先清缓存、重输密码、检查字符串内是否有多余空格反斜杠。

2. 大小写敏感被开启
Oracle 11g 起引入了SEC_CASE_SENSITIVE_LOGON,默认TRUE。如果数据库刚从 10g 升级上来,或者人为改动过参数,以前不区分大小写的密码会突然全都登录失败。
用管理员登录后查看:show parameter sec_case_sensitive_logon
若为 TRUE 而你的旧程序只传了小写密码,可选两种方式之一:

3. 账户被锁或过期
密码到期或多次失败被锁,也会直接报 ORA-01017,而不提示真正的锁定信息。
查询状态:select username, account_status from dba_users where username = '目标用户';

4. 缺「CREATE SESSION」权限
新建用户最容易遗漏这步。刚create user identified by ...之后,如果没有单独grant create session to 用户名;,登录时就是一个 ORA-01017。
用 sys 或 system 登录后执行授权即可,也可一并授予 connect 角色。

5. 连接串写错服务名
虽然不太常见,但把 SID 写成 SERVICE_NAME 或者 IP 指向了错误的节点,也能收到 ORA-01017,因为目标库上压根没有该用户。先tnsping 连接名看返回的服务是否是你想要的那一个。

我根据上面的步骤逐个查了一遍,还是没有解决问题,后来在网上查到一种情况,让我豁然开朗。原来从 12c 开始,密码存储引入了多种验证协议,如果客户端版本过旧或驱动不支持高版本协议,可能协商失败表现为 ORA-01017。

检查dba_users视图:

SQL> select username, password_versions from dba_users where username='DXCAP';

USERNAME

-------------------------------------------------------------------------------

PASSWORD_VERSIONS

-----------------

DXCAP

11G 12C

应该只允许11.2.0.3以上的客户端版本连接。

在这里需要重新修改数据库用户的密码,来激活版本修改。修改用户密码后,再查询dba_users视图。

SQL> select username, password_versions from dba_users where username='DXCAP';

USERNAME

--------------------------------------------------------------------------------

PASSWORD_VERSIONS

-----------------

DXCAP

10G 11G 12C

这次允许10g以上的客户端版本连接数据库了。

问题也解决了,在低版本客户端程序连接高版本服务器时一定要注意这个问题。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/13 12:11:54

2026年高校学生财务入门类证书推荐

高校学生在财务领域入门阶段,考取相关证书能有效提升就业竞争力。以下是2026年值得关注的财务入门类证书,涵盖数据分析、会计、金融等多个方向。 1. CDA数据分析师证书 CDA数据分析师证书(Certified Data Analyst)是面向数据分析…

作者头像 李华
网站建设 2026/6/13 12:09:58

如何用NSC_BUILDER批量处理Switch游戏文件:终极完整指南

如何用NSC_BUILDER批量处理Switch游戏文件:终极完整指南 【免费下载链接】NSC_BUILDER Nintendo Switch Cleaner and Builder. A batchfile, python and html script based in hacbuild and Nuts python libraries. Designed initially to erase titlerights encryp…

作者头像 李华
网站建设 2026/6/13 12:08:01

遗传算法工业实战:选择压力、模式保护与多样性调控

1. 项目概述:为什么第二部分比第一部分更值得你花时间重读 “遗传算法”这四个字,我第一次在研究生组会上听到时,导师只用了三分钟画了个流程图:种群、选择、交叉、变异、适应度——然后说,“这就是生物进化在计算机里…

作者头像 李华
网站建设 2026/6/13 12:04:54

MC56F823xx交叉开关与AOI模块配置实战:构建硬件事件处理流水线

1. 项目概述与核心价值在嵌入式系统,尤其是电机控制、数字电源这类对实时性要求极高的领域,如何高效、灵活地管理众多外设信号之间的连接与交互,一直是工程师面临的核心挑战。传统的固定硬件连线或有限的GPIO复用功能,在面对复杂的…

作者头像 李华