当前位置: 首页 > news >正文

遇到一个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以上的客户端版本连接数据库了。

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

http://www.zskr.cn/news/1516969.html

相关文章:

  • 主流 MP3 音频转换工具大全,免费软件适配音频剪辑日常使用 - 软件工具教程方法
  • 微信私域机器人开发:iPad协议API实战指南
  • YaeAchievement:3分钟搞定原神成就数据导出,告别手动记录的烦恼
  • 考研数学积分题总丢分?掌握这3个对称区间和三角函数的‘秒杀’性质,计算速度翻倍
  • 嵌入式设备日志自动备份:用Dropbear+SCP免密传输,5分钟搞定脚本配置
  • YimMenu:GTA5终极防护与增强菜单完全指南
  • Java 标准 JAXP(Java API for XML Processing),JDK 内置,无需额外引入第三方依赖
  • netstat命令和ss命令详解
  • PythonVista:突破系统限制,为老旧Windows重新定义Python兼容性边界
  • 2026运城旧金铂银回收黄金回收高信誉门店汇总 5 家线下实体回收商家实地评测与联络渠道整理 - 中业金奢再生回收中心
  • 硬件工程师踩过的坑:Buck电路PCB布局的10个细节(附AD/嘉立创实战案例)
  • 路灯智能控制模块怎么选型?看光控时控经纬度远程四大功能
  • FPGA实战(07): Verilog 实现带符号输出的 0~99 循环计数器(tops 模块)设计与仿真
  • PyTorch-NPU/stable-diffusion-2-1:华为NPU优化的AI绘画模型完全指南 [特殊字符]
  • 基于plc的楼宇供电控制系统及综合防雷设计23(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 2026大同市卡地亚+GP芝柏表手表专业回收,26年精选回收店铺排行榜推荐 - 莘州文化
  • 团队API文档难维护?怎么用 Claude 快速生成 Markdown?一文看懂选型与实战指南
  • 2026年北京财务管理公司对比测评,代理记账机构哪家强? - 互联百晓生
  • 2026伊犁市百达翡丽+宝珀手表专业回收,26年精选回收店铺排行榜推荐 - 莘州文化
  • 基于PLC控制的铺丝机总体及其控制系统设计23(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 数据分析师的肌肉记忆:原始数据诊断四层校验法
  • 告别信号衰减!手把手教你制作7/8馈线接头(附工具清单与防短路技巧)
  • M68000处理器数据格式详解:从整数到浮点数的底层表示与对齐优化
  • 嵌入式以太网驱动深度解析:从ENET硬件到SDK实战
  • FPGA实战(10):FPGA全流水复数乘法器设计及自动化验证(Verilog)
  • 终极指南:三步快速解锁原神60FPS限制,享受丝滑游戏体验
  • 经验分享:2026京东 E 卡回收常见骗局拆解与安全交易方案 - 京卡收卡券回收
  • 2026年上海采购新人CPPM报名前需要准备什么?众智商学院官网入门条件与资料清单确认 - 众智商学院职业教育
  • 手机必备的百宝箱 !装机必备的多功能工具app!一站式解决你的日常小需求
  • 2026免费微信投票制作系统推荐:火星投票快速上手攻略,批量导入+强防刷 - 微信投票小程序