解决oracle数据库乱码

简介: 解决oracle数据库乱码

解决oracle数据库乱码


1.将以下代码保存为xxx.bat放入plsql的安装目录下双击并启动plsql,就可解决初始化数据时的乱码。(数据库的编码格式为GBK的才管用)

set nls_lang=SIMPLIFIED CHINESE_CHINA.ZHS16GBK
PLSQLDev.exe


2.在Redhat上安装Oracle 10g没有设定字符集,采用的是操作系统默认字符集:WE8ISO8859P1,将字符集修改为:ZHS16GBK。

由于过程不可逆,首先需要备份数据库。


1.数据库全备


2.查询当前字符集


SQL> select * from nls_database_parameters where parameter=‘NLS_CHARACTERSET’;

PARAMETER VALUE


NLS_CHARACTERSET WE8ISO8859P1


3.关闭数据库


SQL> shutdown immediate

Database closed.

Database dismounted.

ORACLE instance shut down.


4.启动数据库到mount状态


SQL> startup mount

ORACLE instance started.

Total System Global Area 205520896 bytes

Fixed Size 1266608 bytes

Variable Size 100666448 bytes

Database Buffers 100663296 bytes

Redo Buffers 2924544 bytes

Database mounted.


5.限制session


SQL> alter system enable restricted session;

System altered.


6.查询相关参数并修改


SQL> show parameter job_queue_processes;

NAME TYPE VALUE


job_queue_processes integer 10

SQL> show parameter aq_tm_processes;

NAME TYPE VALUE


aq_tm_processes integer 0

SQL> alter system set job_queue_processes=0;

System altered.


7.打开数据库


SQL> alter database open;

Database altered.


8.修改字符集


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

出现错误提示,新字符集必须是老字符集的超集,也就原来字符集是新字符集的子集,可以再Oracle官方文档上查询字符集包含关系。(参考http://www.wityx.com/database/)下面使用Oracle内部命令internal_use,跳过超集检查,生产环境不建议使用此方法。

SQL> alter database character set internal_use ZHS16GBK;

Database altered.


9.查询当前字符集


SQL> select * from nls_database_parameters where parameter=‘NLS_CHARACTERSET’;

PARAMETER VALUE


NLS_CHARACTERSET ZHS16GBK


10.关闭数据库


SQL> shutdown immediate

Database closed.

Database dismounted.

ORACLE instance shut down.


11.启动数据库到mount状态


SQL> startup mount

ORACLE instance started.

Total System Global Area 205520896 bytes

Fixed Size 1266608 bytes

Variable Size 100666448 bytes

Database Buffers 100663296 bytes

Redo Buffers 2924544 bytes

Database mounted.


12.将相关参数改回原来值


SQL> alter system set job_queue_processes=10;

System altered.


13.打开数据库


SQL> alter database open;

Database altered.



相关文章
|
1月前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
164 64
|
23天前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
29 7
|
23天前
|
Oracle 关系型数据库 数据库
oracle数据库技巧
【10月更文挑战第25天】oracle数据库技巧
25 6
|
23天前
|
存储 Oracle 关系型数据库
Oracle数据库优化策略
【10月更文挑战第25天】Oracle数据库优化策略
20 5
|
30天前
|
存储 Oracle 关系型数据库
数据库数据恢复—Oracle ASM磁盘组故障数据恢复案例
Oracle数据库数据恢复环境&故障: Oracle ASM磁盘组由4块磁盘组成。Oracle ASM磁盘组掉线 ,ASM实例不能mount。 Oracle数据库故障分析&恢复方案: 数据库数据恢复工程师对组成ASM磁盘组的磁盘进行分析。对ASM元数据进行分析发现ASM存储元数据损坏,导致磁盘组无法挂载。
|
1月前
|
监控 Oracle 关系型数据库
Oracle数据库性能优化
【10月更文挑战第16天】Oracle数据库性能优化是
30 1
|
1月前
|
存储 Oracle 关系型数据库
【数据库-Oracle】《Oracle 数据库探秘:基础知识点全攻略》
《Oracle 数据库探秘:基础知识点全攻略》深入介绍 Oracle 数据库的基础知识点,包括数据类型、表结构、查询语句等。通过详细讲解、代码示例和流程图,帮助读者快速掌握 Oracle 数据库的基本操作,为数据库开发和管理打下坚实基础。
38 0
|
3月前
|
监控 Oracle 关系型数据库
"深度剖析:Oracle SGA大小调整策略——从组件解析到动态优化,打造高效数据库性能"
【8月更文挑战第9天】在Oracle数据库性能优化中,系统全局区(SGA)的大小调整至关重要。SGA作为一组共享内存区域,直接影响数据库处理能力和响应速度。本文通过问答形式介绍SGA调整策略:包括SGA的组成(如数据缓冲区、共享池等),如何根据负载与物理内存确定初始大小,手动调整SGA的方法(如使用`ALTER SYSTEM`命令),以及利用自动内存管理(AMM)特性实现智能调整。调整过程中需注意监控与测试,确保稳定性和性能。
306 2
|
4月前
|
存储 缓存 Oracle
Oracle数据库可扩展性和性能
【7月更文挑战第6天】
85 7
|
存储 SQL 负载均衡
达梦数据库与Oracle数据库:功能、性能和适用场景对比
数据库在现代信息技术领域中扮演着至关重要的角色。在企业级应用中,选择正确的数据库管理系统对于数据存储、处理和查询效率至关重要。本文将对比两个备受关注的数据库管理系统——达梦数据库和Oracle数据库,从功能、性能和适用场景等方面进行深入探讨,以帮助读者在选择合适数据库时做出明智的决策。
2808 1

推荐镜像

更多