oracle修改字符集----转载自Linux公社
2015-11-10 16:08
477 查看
环境:
OS:Red Hat Linux
As 5
DB:Oracle 10.2.0.4
通常情况下,字符集是在安装的时候选定好的,需要修改数据库的字符集Oracle建议的做法是重建数据库(EXP/EXPDP导出后再导入),虽然Oracle官方文档也有说如何修改字符集,但这不是Orale推荐的方法.下面是Oracle官方文档中提到的如何修改字符集的方法.
1.查看当前数据库字符集
select * from nls_database_parameters
where parameter='NLS_CHARACTERSET';
-----------------------------------
PARAMETER VALUE
NLS_CHARACTERSET WE8ISO8859P1
这里的字符集WE8ISO8859P1是不支持中文的
2.将字符集修改为中文字符集ZHS16GBK
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> STARTUP MOUNT;
ORACLE instance started.
Total System Global Area 734003200 bytes
Fixed Size 1221564
bytes
Variable Size 264244292
bytes
Database Buffers 465567744
bytes
Redo Buffers 2969600
bytes
Database mounted.
SQL> ALTER SYSTEM ENABLE RESTRICTED SESSION;
System altered.
SQL> ALTER DATABASE OPEN;
Database altered.
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
SQL> ALTER DATABASE character set INTERNAL_USE ZHS16GBK;
Database altered.
SQL> SHUTDOWN IMMEDIATE;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.
Total System Global Area 734003200 bytes
Fixed Size 1221564
bytes
Variable Size 264244292
bytes
Database Buffers 465567744
bytes
Redo Buffers 2969600
bytes
Database mounted.
Database opened.
这样将数据库的字符集由原来的WE8ISO8859P1修改成了ZHS16GBK,对原来的字符集有中文的显示的还是乱码,但对新入库的中文字符集就能正常显示.
-- The End --
郑重声明:本博文内容转自自Linux公社
OS:Red Hat Linux
As 5
DB:Oracle 10.2.0.4
通常情况下,字符集是在安装的时候选定好的,需要修改数据库的字符集Oracle建议的做法是重建数据库(EXP/EXPDP导出后再导入),虽然Oracle官方文档也有说如何修改字符集,但这不是Orale推荐的方法.下面是Oracle官方文档中提到的如何修改字符集的方法.
1.查看当前数据库字符集
select * from nls_database_parameters
where parameter='NLS_CHARACTERSET';
-----------------------------------
PARAMETER VALUE
NLS_CHARACTERSET WE8ISO8859P1
这里的字符集WE8ISO8859P1是不支持中文的
2.将字符集修改为中文字符集ZHS16GBK
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> STARTUP MOUNT;
ORACLE instance started.
Total System Global Area 734003200 bytes
Fixed Size 1221564
bytes
Variable Size 264244292
bytes
Database Buffers 465567744
bytes
Redo Buffers 2969600
bytes
Database mounted.
SQL> ALTER SYSTEM ENABLE RESTRICTED SESSION;
System altered.
SQL> ALTER DATABASE OPEN;
Database altered.
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
SQL> ALTER DATABASE character set INTERNAL_USE ZHS16GBK;
Database altered.
SQL> SHUTDOWN IMMEDIATE;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup
ORACLE instance started.
Total System Global Area 734003200 bytes
Fixed Size 1221564
bytes
Variable Size 264244292
bytes
Database Buffers 465567744
bytes
Redo Buffers 2969600
bytes
Database mounted.
Database opened.
这样将数据库的字符集由原来的WE8ISO8859P1修改成了ZHS16GBK,对原来的字符集有中文的显示的还是乱码,但对新入库的中文字符集就能正常显示.
-- The End --
郑重声明:本博文内容转自自Linux公社
相关文章推荐
- Oracle笔记--Sql语句
- oracle 11g 审计
- oracle与木桶原理
- (2)Oracle基础--表空间
- Oracle修改数据表
- oracle 存储过程,存储函数以及定时器的综合使用
- Linux启动oracle
- pb连接oracle问题
- oracle数据库软件静默安装
- oracle数据库软件静默安装
- oracle数据库软件静默安装
- oracle多表查询(外连接,自连接)
- oracle单行函数
- oracle重点内容
- oracle 闪回
- 测试oracle存储过程,光标,连接等的java代码
- java-oracle数据库连接
- Oracle和sqlserver关于锁和隔离级别的差异
- oracle违反完整约束条件
- oracle,重点处理数据语句