Oracle数据库中出现ora-12899错误怎么办

在使用oracle的过程中,会出现各种各样的问题,各种各样的错误,其中ora-12899就是前段时间我在将数据导入到我本地机器上的时候一直出现的问题.不过还好已经解决了这个问题,现在分享一下,希望能帮助到大家。

出现ORA-12899,是字符集引起的,中文在UTF-8中占3个字节,ZHS16GBK中占2个字节,而源dmp文件字符集是ZHS16GBK库里倒出来的数据,现在要导入到目标字符集为UTF-8的库里,所以会出现ORA-12899

其实只要修改一下ORACLE 的字符集就可以很好的解决这个问题;

但是在修改字符集的时候,我发现,我把sys账户的密码给忘记了,这就悲剧了,所以我只好先修改sys用户的密码咯. 

修改密码也是分好几种情况的,下面我就一一列举吧:

一、忘记除SYS、SYSTEM用户之外的用户的登录密码。

用SYS (或SYSTEM)用户登录。

CONN SYS/PASS_WORD AS SYSDBA;

使用如下语句修改用户的密码。

ALTER USER user_name IDENTIFIED BY newpass;

注意:密码不能全是数字。并且不能是数字开头。否则会出现:ORA-00988: 口令缺失或无效

二、忘记SYS用户,或者是SYSTEM用户的密码。

如果是忘记SYSTEM用户的密码,可以用SYS用户登录。然后用ALTER USER 密令

修改密码。

CONN SYS//PASS_WORD AS SYSDBA; ALTER USER SYSTEM IDENTIFIED BY newpass;

如果是忘记SYS用户的密码,可以用SYSTEM用户登录。然后用ALTER USER 密令

修改密码。

CONN SYSTEM//PASS_WORD ; ALTER USER SYSTEM IDENTIFIED BY newpass;

三、如果SYS,SYSTEM用户的密码都忘记或是丢失。

这一项尤其重要。

可以使用ORAPWD.EXE 工具修改密码。

开始菜单->运行->输入‘CMD’,打开命令提示符窗口,输入如下命令:

orapwd file=D:/oracle/product/10.2.0/db_1/database/pwdctcsys.ora password=newpass

这个命令重新生成了数据库的密码文件。密码文件的位置在ORACLE_HOME目录下
的/database目录下。

阿里云-虚拟数字人 阿里云-虚拟数字人

阿里云-虚拟数字人是什么? …

阿里云-虚拟数字人 2 查看详情 阿里云-虚拟数字人

这个密码是修改sys用户的密码。除sys和system其他用户的密码不会改变。 

修改过密码之后就能以dba的身份进行修改了,不是dba的话在执行修改命令的时候会提示你权限不足.

开始–>运行–>cmd,之后输入:”sqlplus sys/oracle@192.168.0.1/orcl as SYSDBA

如果不能正常进入,那就需要你手动输入用户名和密码,进入之后会出现”SQL>”的提示,按照下面给出的命令依次执行就可以了,

SQL>SHUTDOWN IMMEDIATESQL>STARTUP MOUNTSQL>ALTER SYSTEM ENABLE RESTRICTED SESSION;SQL>ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;SQL>ALTER SYSTEM SET AQ_TM_PROCESSES=0;SQL>ALTER DATABASE OPEN;SQL> ALTER DATABASE CHARACTER SET ZHS16GBK ;ALTER DATABASE CHARACTER SET ZHS16GBK*ERROR at line 1:ORA-12712: new character set must be a superset of old character set

报字符集不兼容,此时下INTERNAL_USE指令不对字符集超集进行检查:

SQL>ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK;SQL>SHUTDOWN IMMEDIATESQL>STARTUP

这时候,这个ORA-12899就已经彻底解决了,就可以进行数据的导入了…

PS:下面给大家补充下:oracle 里*.ora文件是干什么用的?

为什么10g里边没有*.ora文件?

9i里边的*.ora 等于10g里边的*.dbf么?

在创建表空间

 DATAFILE 用于指定数据文件的具体位置和大小。但是我看到有些文章使用

 *.ora文件,如DATAFILE 'D:ORACLEORADATAORA92LUNTAN.ora' SIZE 5M ,有些

 则使用*.dbf文件,如DATAFILE 'D:ORACLEORADATAORA92LUNTAN.dbf' SIZE 5M 。 

网上的说法是.dbf-数据文件, .tmp-临时文件, .log-重作日志文件(redo log file), .ctl-控制文件

 .ora-参数文件, .dat-Oracle系统文件 

只是通过扩展名来标识文件的类型而已,对于数据文件不管是ora/dat/dbf,都是一样的,没有什么区别。我个人觉得也是这样。不知大家的意见是怎样的?

相关推荐:

Oracle如何更改表空间的数据文件位置

mysql与oracle数据库停止与启动的批处理文件

Oracle Clob字段过长保存出错改如何解决?

以上就是Oracle数据库中出现ora-12899错误怎么办的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/387253.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 14:10:46
下一篇 2025年11月6日 14:16:24

相关推荐

  • MySQL INSERT 语句可读性优化:利用 SET 语法提升代码清晰度

    本文探讨了在mysql中优化`insert`语句可读性的方法。针对传统`insert … values`语法在处理大量列时难以匹配值与列名的问题,推荐使用`insert … set`语法。这种方式能显著提升sql语句的清晰度,使开发者更容易理解和维护代码,尤其适用于go等语言…

    2025年12月16日
    000
  • 提升MySQL INSERT 语句清晰度:SET 语法详解

    本文旨在解决sql `insert` 语句在处理大量字段时可读性差的问题。传统 `values` 列表语法使得列与值难以对应,降低了代码清晰度。我们将介绍并详细阐述mysql中更为优雅的 `insert … set` 语法,通过直接将列与值关联,显著提升语句的可读性和维护性,特别适用于需…

    2025年12月16日
    000
  • 深入探讨Go语言crypto库与OpenSSL的安全性对比及生产环境考量

    本文探讨go语言标准库crypto/tls在生产环境中的安全性,并与openssl进行比较。go的tls实现存在已知侧信道攻击风险,且缺乏外部安全审计,因此在某些关键场景下可能不足以满足生产需求。文章分析了具体漏洞,并指出在go标准库层面,目前尚无官方推荐的go调用openssl库的方法。 Go语言…

    2025年12月16日
    000
  • Go lib/pq驱动中PostgreSQL SQL占位符的正确使用指南

    在使用go语言的`lib/pq`驱动连接postgresql时,sql查询中的占位符应采用`$n`(如`$1`、`$2`)而非通用的`?`。本文将详细解释这一postgresql特有的语法要求,并通过示例代码演示如何正确地构建和执行参数化查询,从而避免常见的语法错误,确保数据库操作的安全性与高效性。…

    2025年12月16日
    000
  • OAuth响应处理与安全会话管理:数据库集成与Cookie最佳实践

    本教程深入探讨了OAuth2认证流程结束后,如何安全高效地处理用户数据并建立会话。文章首先介绍了将OAuth提供者返回的用户数据存储到数据库的最佳实践,重点讲解了原子性的UPSERT操作以避免数据冗余和竞态条件。随后,详细阐述了基于Cookie的会话管理策略,强调了使用HTTPS、Secure、Ht…

    2025年12月16日
    000
  • Golang如何实现自动化备份与恢复

    Go语言适合构建自动化备份与恢复系统,其核心是通过调用系统命令或API实现数据备份与恢复。1. 文件备份可使用os和io包复制文件,数据库备份可通过mysqldump等工具或驱动导出;2. 使用robfig/cron库设置定时任务,如每日2点执行备份,并结合systemd或Kubernetes管理任…

    2025年12月16日
    000
  • Golang集成数据库客户端开发环境配置

    首先安装Go环境并配置GOROOT、GOBIN与PATH,验证go version;接着通过go mod init创建项目,使用go get引入如github.com/go-sql-driver/mysql等对应数据库驱动,并在代码中匿名导入以注册驱动;然后调用sql.Open()传入驱动名和DSN…

    2025年12月15日
    000
  • Golang测试代码生成 自动化生成测试用例

    自动化生成Golang测试用例的核心在于结合Fuzzing、反射和代码生成工具。Go内置Fuzzing能自动探索输入并发现崩溃,解决输入多样性问题;反射可用于自动生成复杂结构体的测试数据,提升数据准备效率;gopter等PBT库则通过定义代码属性验证逻辑正确性;而外部依赖模拟和“神谕问题”仍需人工设…

    2025年12月15日
    000
  • Golang的crypto库如何实现数据加密 演示AES和RSA最佳实践

    golang的crypto库为数据加密提供了坚实的基础,它不是一个单一的“加密”功能,而是一系列密码学原语的集合。在实际应用中,aes(高级加密标准)凭借其对称加密的高效性,成为处理大量数据的首选,尤其是在gcm模式下,它能同时提供数据的机密性、完整性和认证。而rsa(rivest-shamir-a…

    2025年12月15日 好文分享
    000
  • Golang如何优化加密运算 使用硬件加速指令提升AES性能

    要优化golang中的aes加密性能,关键在于利用硬件加速和高效模式。1. 使用标准库crypto/aes包,其已自动启用aes-ni指令;2. 确认cpu支持aes-ni;3. 采用gcm模式提升性能与安全性;4. 复用cipher实例避免重复初始化;5. 利用并发处理大数据块;6. 减少内存拷贝…

    2025年12月15日 好文分享
    000
  • Golang数据库操作指南_go连接MySQL实战

    golang连接mysql需使用database/sql包及驱动。1.安装推荐的mysql驱动github.com/go-sql-driver/mysql;2.通过sql.open创建连接池并用db.ping测试连接;3.查询时使用rows.scan读取数据并确保关闭rows;4.更新操作使用db.…

    2025年12月15日 好文分享
    000
  • Debian系统如何监控JSP应用的运行状态

    在Debian操作系统中,对JSP应用进行运行状态监控可以采用多种方式和相关工具。以下是一些常见的方法: 1. 利用SpringBoot内置的性能监控功能 如果JSP项目是基于SpringBoot构建的,可以使用其自带的性能监控组件。SpringBoot提供了一些基础的监控类,比如Performan…

    2025年12月15日
    000
  • Debian下sqlplus使用技巧有哪些

    在Debian操作系统中使用SQL*Plus时,掌握一些实用技巧可以显著提升操作效率和管理体验。以下是一些常用的技巧: 增强命令行操作:通过安装rlwrap工具来实现命令历史浏览和上下文切换功能。具体步骤如下: sudo apt-get install rlwrap echo “alias sqlp…

    2025年12月15日
    000
  • 如何在Debian中提高phpstorm的稳定性

    在Debian系统中增强PhpStorm的稳定性可通过以下几种方式实现: 维持软件更新: 定期将PhpStorm升级至最新版本,例如PhpStorm 2018.1版本包含了大量错误修正及功能优化。同时也要确保Debian系统的全面更新,这样可以有效规避潜在的兼容性冲突。 选择合适的JVM: PhpS…

    2025年12月15日
    000
  • 使用Go语言连接Oracle数据库时是否需要安装Oracle客户端?

    Go语言连接Oracle数据库:是否必须安装Oracle客户端? 在Go语言开发中连接Oracle数据库是常见需求。许多教程和示例都建议安装Oracle客户端,这在Windows桌面开发和Linux生产环境中可能带来配置上的差异和不便。那么,Go语言的Oracle数据库驱动程序能否绕过Oracle客…

    2025年12月15日
    000
  • 在Go语言中使用Oracle驱动是否需要安装Oracle客户端?

    Go语言连接Oracle数据库:是否需要Oracle客户端? 许多Go语言开发者在连接Oracle数据库时,都会纠结于是否需要安装Oracle客户端。网上的许多示例都依赖于Oracle客户端,这无疑增加了跨平台部署的复杂性(例如,开发环境为Windows,生产环境为Linux)。 那么,Go语言的O…

    2025年12月15日
    000
  • 在Go中使用Oracle数据库驱动是否需要安装Oracle客户端?

    Go语言连接Oracle数据库:Oracle客户端并非必需 在Go语言开发中连接Oracle数据库,开发者常面临一个关键问题:是否必须安装Oracle客户端?尤其在Windows开发环境与Linux生产环境切换时,这个问题显得尤为重要。 许多教程都包含安装Oracle客户端的步骤,这无疑增加了开发和…

    2025年12月15日
    000
  • python oracle数据库如何安装?

    首先安装Oracle Instant Client并配置环境变量,再通过pip install oracledb安装Python驱动,最后用代码测试连接;确保客户端版本与系统匹配,并正确设置PATH、LD_LIBRARY_PATH或DYLD_LIBRARY_PATH以避免常见错误。 要在Python…

    2025年12月14日
    000
  • python-oracledb 游标对象与数据库会话管理深度解析

    本文深入探讨 `python-oracledb` 库中游标对象(Cursor Object)及其变量(Cursor Variable)的工作原理与生命周期。我们将阐明 `cursor.var()` 创建的变量在 Python 客户端和 Oracle 数据库会话之间的关系,纠正关于其值持久性的常见误解…

    2025年12月14日
    000
  • SQLAlchemy 声明式模型中指定数据库表模式(Schema)的方法

    本文详细介绍了如何在使用 sqlalchemy 声明式 api 定义和创建数据库表时,指定表所属的数据库模式(schema)。通过在声明式模型类中利用 `__table_args__` 属性并设置 `schema` 参数,开发者可以精确控制表在数据库中的位置,从而避免默认的“public”模式,尤其…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信