- 浏览: 952328 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (1037)
- [随笔分类]oracle (34)
- [随笔分类]知识学习 (141)
- [随笔分类]客户端javascript (29)
- [随笔分类]经验总结 (2)
- [随笔分类]数据库 (18)
- [随笔分类]心情 (4)
- [随笔分类]心得 (3)
- [随笔分类]页面框架 (2)
- [随笔分类]服务器C#语法总结 (41)
- [随笔分类]知识产权 (1)
- [网站分类]3.非技术区 (3)
- [随笔分类]Seo学习 (3)
- [随笔分类]程序 (8)
- [随笔分类]生活常识 (0)
- [随笔分类]炒股 (16)
- [网站分类]4.其他技术区 (1)
- 4.其他技术区 (0)
- 3.非技术区 (0)
- 2.Java新手区 (0)
最新评论
-
luoxiaoyan3817:
...
性感美女|青春美女|成熟美女 -
a1350258:
这个和标题简直是驴唇不对马嘴吧,,,,,,,,,,,,,,,, ...
java 打包命令 -
windFeng:
谢谢兄台,以上链接现在都还可以用迅雷下载!
Oracle 9i 下载地址|Oracle 9i 下载|Oracle 9i 官网下载地址 -
gray:
入门教程。
rdlc数据报表的使用reportview -
Rong_it:
Tang.Scholar 写道感觉蛮爽的 你写一下就不觉得爽了 ...
需求分析书规范
关于ORACLE数据库中汉字显示乱码问题的探讨
1 引言 ORACLE数据库作为业界领先的数据库产品,近年来在国内大中型企业中得到了广泛的应用。虽然ORACLE数据库产品本身在本地化方面已做得相当成熟,但还是有不少用户反应汉字显示乱码的问题。如对同一数据库不同的用户对同一表中的username查询却得出了不同的结果: “ORACLE??????”和“ORACLE中国有限公司”,显然结果中将中文字符显示为乱码,那么为什么呢?字符集的设置不当是影响ORACLE数据库汉字显示的关键问题。
2 关于字符集 字符集是ORACLE为适应不同语言文字显示而设定的。用于汉字显示的字符集主要有ZHS16CGB231280、ZHS16GBK、US7ASCII和UTF-8等。字符集同时存在于服务器端和客户端。服务器端字符集是在安装ORACLE时指定的,字符集登记信息存储在ORACLE数据库字典的V$NLS_PARAMETERS表中;而客户端字符集是在系统注册表(WINDOWS系统)或在用户的环境变量(UNIX系统)中设定的。
3 字符集的构成与设定 字符集的构成与设定方式分为客户端与服务器端两种:
(1)客户端字符集的构成与设定。客户端的字符集是由当前用户的环境变量NLS_LANG设定的。环境变量NLS_LANG的构成:
NLS_LANG=language_territory.charset
其中,
language 指定服务器消息的语言
territory 指定服务器的日期和数字格式
charset 指定字符集
三个成分可以任意组合,例如:
AMERICAN_AMERICA.US7SCII
SIMPLIFIED CHINESE_CHINA.ZHS16GBK
AMERICAN_AMERICA. ZHS16GBK
客户端字符集的设定方法针对不同操作系统设定方法稍有不同:WINDOWS系统是在注册表项:HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0\NLS_LANG中设定;UNIX系统是在当前用户的环境变量中设定,如在当前用户的profile文件中增加一行如下代码:
NLS_LANG=SIMPLIFIED Chinese_CHINA.ZHS16GBK;export NLS_LANG
(2)服务端字符集的构成与设定。服务端字符集的构成体现在数据字典表V$NLS_PARAMETERS的NLS_LANGUAGE、NLS_TERRITORY、NLS_CHARACTERSET三项取值上,其中NLS_CHARACTERSET的取值就是具体的数据库字符集。
如利用查询语句SQL>SELECT * FROM V$NLS_PARAMETERS;
可得到如下结果:
PARAMETER VALUE
------------------------------------------------------------
NLS_LANGUAGE SIMPLIFIED CHINESE
NLS_TERRITORY CHINA
……
NLS_CHARACTERSET ZHS16GBK
……
即当前数据库使用的字符集是ZHS16GBK。
数据库服务端的字符集是在创建数据时设定的。但可通过如下方法对已设定的字符集进行修改:
方法一:重建数据库。建立数据库时将数据库的字符集设定为所需字符集。
方法二:修改SYS.PROPS$表。即用SYS用户登陆ORACLE后,利用下面语句修改相应的字符集并提交:
SQL>UPDATE PROPS$ SET VALUE$=’ZHS16GBK‘
WHERE NAME=’NLS_CHARACTERSET’;
SQL>COMMIT;
通过此种方法来更改数据库字符集,只对更改后的数据有效,即数据库中原来的数据仍以原字符集被存储。
另外,有的还利用CREATE DATABASE CHARACTER SET ZHS16GBK命令暂时的修改字符集,当重启数据库后,数据库字符集将恢复原来的字符集。
4 常见的汉字乱码问题及解决方案 要在客户端正确显示ORACLE数据库中的汉字信息,首先必须使客户端的字符集与服务器端的字符集一致;其次是加载到ORACLE数据库的数据字符集必须与服务器字符集一致。据此,汉字显示乱码的问题大致可以分为以下几种情况:
(1)客户端字符集与服务器端字符集不同,服务器端字符集与加载数据字符集一致。这种情况是最常见的,只要把客户端的字符集设置正确即可。具体解决方案:
第一步:查询V$NLS_PARAMETERS得到服务端的字符集:
SQL>SELECT * FROM V$NLS_PARAMETERS;
第二步:根据服务端的字符集设定客户端的字符集,设定方法参见客户端的字符集的设定方式。
以UNIX系统为例,可在当前用户的profile文件中增加如下两行:
NLS_LANG=SIMPLIFIED Chinese_CHINA.ZHS16GBK
export NLS_LANG
(2)客户端字符集与服务器端字符集相同,服务器端字符集与加载数据字符集不一致。这种情况一般发生在ORACLE版本升级或重新安装数据库时选择了与原来数据库不同的字符集,而恢复加载的备份数据仍是按原字符集卸出的场合。另一种情况是加载从其它使用不同字符集的ORACLE数据库卸出的数据。在这两种情况中,不管客户端字符集与服务器端字符集是否一致都无法正确显示汉字。具体解决方案:
方案一:按服务端字符集的修改方法修改服务端字符集与加载数据字符集一致,然后导入数据。
方案二:利用数据格式转储,避开字符集带来的问题。即先将加载数据倒入到与其字符集一致的数据库中,然后再将数据要么按文本格式导出(数据量较小的情况下),要么通过第三方工具(如POWER BUILDER,ACCESS,FOXPRO等)倒出数据,最后将倒出的数据导入到目标数据库中。
(3)客户端字符集与服务器端字符集不同,服务端字符集与输入数据字符集不同。这种情况是在客户端字符集与服务器端字符集不一致时,从客户端输入了汉字信息。输入的这些信息即便是把客户端字符集更改正确,也无法显示汉字。解决方案:修改客户端字符集与服务端字符集一致后,重新输入数据。
其中: sqlplus乱码解决 export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK (显示英文) 或 export NLS_LANG="SIMPLIFIED CHINESE"_CHINA.zhs16cgb231280 5 结束语 根据ORACLE官方文档的说明,一旦数据库创建后,数据库的字符集是不能改变的。因此,提前考虑自己的数据库将选用哪一种字符集是十分重要的。数据库字符集选择的一般规则是将数据库字符集设定为操作系统本地字符集的一个超集,同时数据库字符集也应该是所有客户字符集的超集。如同样是中文环境,在选择ZHS16CGB231280还是ZHS16GBK时,我们更多的情况是选择ZHS16GBK,因为它包含了ZHS16CGB231280字符集。
参考文献 1 (美)JONATHAN GENNICK CAROL MCCULLOUGH-DIETER GERRIT-JAN LINKER ,译者:赵艳勤, 刘冠英, 秦玉杰 等.《ORACLE8I DBA宝典》.电子工业出版社
2 JASON COUCHMAN,SUDHEER MARISETTI.《OCP ORACLE9I DATABASE:FUNDAMENTALS I EXAM GUIDE》.出版社: MCGRAW-HILL
3 ORACLE Corporation.ORACLE 9i Database Administration Fundamentas I Student Guide》
|
发表评论
-
plsql7下载|plsql下载|PlSqlDev下载破解版下载
2010-11-26 22:15 1410PlSqlDev下载|PlSqlDev下载破解版下载|PlSq ... -
pl sql developer|oracle pl sql developer|oracle pl sql 8 developer
2010-09-30 21:33 797plsql pl/SQL Developer 是一个为 Ora ... -
plsql 破解|oracle plsql 破解
2010-09-30 21:36 893plsql 破解|oracle plsql 破解 http:/ ... -
plsql 下载|oracle plsql 下载|plsql 7.1.3下载
2010-09-09 09:08 872plsql 下载 PL/SQL Developer Vers ... -
plsql8下载|plsql8最新版下载|plsql下载
2010-09-11 12:35 1275plsql pl/SQL Developer 是一个为 Ora ... -
plsql注册机下载|plsql8注册机下载
2010-09-11 12:40 1185可以随即生成plsql的序列号 productcode:lf4 ... -
plsql序列号|plsql8序列号
2010-09-11 12:42 1065plsql8序列号|plsql序列号 productcod ... -
plsql 注册码|plsql8注册码
2010-09-12 10:01 1646plsql8注册码 下面是我新生成 新生成的plsql的注册码 ... -
改变oracle 服务器端的字符集编码
2010-09-25 14:34 1097改变oracle 服务器端的字符集编码select * fro ... -
网站系统登陆模版
2010-09-26 16:22 777网站系统登陆模版 http://files.cnblogs.c ... -
pl sql developer|oracle pl sql developer|oracle pl sql 8 developer
2010-09-30 21:33 591plsql pl/SQL Developer 是一个为 Ora ... -
plsql 破解|oracle plsql 破解
2010-09-30 21:36 744plsql 破解|oracle plsql 破解 http:/ ... -
11111
2010-09-30 12:29 6201 -
Oracle10g下载|官网下载|下载地址
2010-08-20 17:50 2137Oracle10g下载|官网下载|下载地址 Oracle Da ... -
Oracle 9i 下载地址|Oracle 9i 下载|Oracle 9i 官网下载地址
2010-07-30 10:08 4744Oracle 9i 下载地址:官方网站下载地址 可能需要你的 ... -
PLSQL PL/SQL Developer下载|PlSql下载破解版下载|oracle PlSql下载
2010-07-31 10:18 1573PlSqlDev下载|PlSqlDev下载破解版下载|PlSq ... -
简单的oracle触发器例子
2010-07-14 16:59 1155简单的oracle触发器例子 ---术前访视术后随访触发器cr ... -
完全卸载oracle|oracle卸载|彻底卸载oracle
2010-07-21 14:42 993完全卸载oracle|oracle卸载|彻底卸载oracle ... -
oracle 触发器写法|oracle trigger 语法
2010-05-11 11:25 1430create or replace trigger t_aft ... -
oracle基本数据类型|Oracle 9i 的基本数据类型
2010-05-12 10:03 908Oracle 9i 的基本数据类 ...
相关推荐
通过附件里的命令行,可以实现oracle编码的更改,无需重新安装。
ORACLE数据库命名编码规范,用于在数据库设计和开发中的实用文档
Oracle查看编码格式
编写目的:开发人员使用统一的命名和编码规范,使数据库对象命名及编码风格标准化,可增加程序的可读性,增强系统的可维护性,提高软件的质量。 适用范围:本规范适用于公司范围内以oracle作为后台数据库的应用系统...
Oracle存储过程编码规范.doc
改文档主要介绍oracle报错的错误编码的信息为什么意思
oracle中解决自动插入主键时,自动编码!
在plsql中发现表结构的comment和其他说明出现乱码的情况。
linux 下的 oracle 导入数据库时出现中文乱码,通过修改字符集格式,修改成支持中文的格式。简单易操作。
很少见的哦,数据库方面的资料, 之针对ORACLE.
网上基本找不到,sqlserver2012版本链接oracle乱码问题解决实测版。
NULL 博文链接:https://hw1287789687.iteye.com/blog/2059444
jeesite全国省市区地图编码表数据(Oracle和Mysql),SQL文件中开头有删除表操作,如果原表中有数据,建议先备份,压缩文件中含mysql和oracle的sys_area表数据
OracleEBS编码规范[定义].pdf
在oracle查询删除一个表编码中相同的记录
本节主要介绍了如何查看oracle数据库的编码及修改编码格式,需要的朋友可以参考下
2018-06-20 统计局发布的省市县乡村5级政区划编码 2018最新全国行政区划编码 Oracle。 国家统计局 2018-06-20 发布的最新2018年统计用区划代码和城乡划分代码(截止2017年10月31日) 本次修订增加了一些符合条件的开发...
Oracle错误编码大全[文].pdf
Oracle 编 码 规 范 , 绝 对 经 典