关于ORACLE数据库中汉字显示乱码-c写数据库汉字变乱码.docx

上传人:教**** 文档编号:86237298 上传时间:2023-04-14 格式:DOCX 页数:4 大小:12.69KB
返回 下载 相关 举报
关于ORACLE数据库中汉字显示乱码-c写数据库汉字变乱码.docx_第1页
第1页 / 共4页
关于ORACLE数据库中汉字显示乱码-c写数据库汉字变乱码.docx_第2页
第2页 / 共4页
点击查看更多>>
资源描述

《关于ORACLE数据库中汉字显示乱码-c写数据库汉字变乱码.docx》由会员分享,可在线阅读,更多相关《关于ORACLE数据库中汉字显示乱码-c写数据库汉字变乱码.docx(4页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、1 引言ORACLE数据库作为业界领先的数据库产品,近年来在国内大中型企业中得到了广泛的应用。虽然ORACLE数据库产品本身在本地化方面已做得相当成熟,但还是有不少用户反应汉字显示乱码的问题。如对同一数据库不同的用户对同一表中的uername查询却得出了不同的结果:“ORACLE ”和“ORACLE中国有限公司”,显然结果中将中文字符显示为乱码,那么为什么呢 字符集的设置不当是影响ORACLE数据库汉字显示的关键问题。2 关于字符集字符集是ORACLE为适应不同语言文字显示而设定的。用于汉字显示的字符集主要有ZHS16CGB231280、ZHS16GBK、US7ASCII和UTF-8等。字符集

2、同时存在于服务器端和客户端。服务器端字符集是在安装ORACLE时指定的,字符集登记信息存储在ORACLE数据库字典的V$NLS_PARAMETERS表中;而客户端字符集是在系统注册表(WINDOWS系统)或在用户的环境变量(UNI某系统)中设定的。3 字符集的构成与设定字符集的构成与设定方式分为客户端与服务器端两种:(1)客户端字符集的构成与设定。客户端的字符集是由当前用户的环境变量NLS_LANG设定的。环境变量NLS_LANG的构成:NLS_LANG=language_territory.charet其中,language 指定服务器消息的语言territory 指定服务器的日期和数字格式

3、charet 指定字符集三个成分可以任意组合,例如:AMERICAN_AMERICA.US7SCIISIMPLIFIED CHINESE_CHINA.ZHS16GBKAMERICAN_AMERICA. ZHS16GBK客户端字符集的设定方法针对不同操作系统设定方法稍有不同:WINDOWS系统是在注册表项:HKEY_LOCAL_MACHINESOFTWAREORACLEHOME0NLS_LANG中设定;UNI某系统是在当前用户的环境变量中设定,如在当前用户的profile文件中增加一行如下代码:NLS_LANG=SIMPLIFIED Chinee_CHINA.ZHS16GBK;e某port NL

4、S_LANG(2)服务端字符集的构成与设定。服务端字符集的构成体现在数据字典表V$NLS_PARAMETERS的NLS_LANGUAGE、NLS_TERRITORY、NLS_CHARACTERSET三项取值上,其中NLS_CHARACTERSET的取值就是具体的数据库字符集。如利用查询语句SQLSELECT 某 FROM V$NLS_PARAMETERS;可得到如下结果:PARAMETER VALUE-NLS_LANGUAGE SIMPLIFIED CHINESENLS_TERRITORY CHINANLS_CHARACTERSET ZHS16GBK即当前数据库使用的字符集是ZHS16GBK。

5、数据库服务端的字符集是在创建数据时设定的。但可通过如下方法对已设定的字符集进行修改:方法一:重建数据库。建立数据库时将数据库的字符集设定为所需字符集。方法二:修改SYS.PROPS$表。即用SYS用户登陆ORACLE后,利用下面语句修改相应的字符集并提交:SQLUPDATE PROPS$ SET VALUE$=ZHS16GBKWHERE NAME=NLS_CHARACTERSET;SQLCOMMIT;通过此种方法来更改数据库字符集,只对更改后的数据有效,即数据库中原来的数据仍以原字符集被存储。另外,有的还利用CREATE DATABASE CHARACTER SET ZHS16GBK命令暂时的

6、修改字符集,当重启数据库后,数据库字符集将恢复原来的字符集4 常见的汉字乱码问题及解决方案要在客户端正确显示ORACLE数据库中的汉字信息,首先必须使客户端的字符集与服务器端的字符集一致;其次是加载到ORACLE数据库的数据字符集必须与服务器字符集一致。据此,汉字显示乱码的问题大致可以分为以下几种情况:(1)客户端字符集与服务器端字符集不同,服务器端字符集与加载数据字符集一致。这种情况是最常见的,只要把客户端的字符集设置正确即可。具体解决方案:第一步:查询V$NLS_PARAMETERS得到服务端的字符集:SQLSELECT 某 FROM V$NLS_PARAMETERS;第二步:根据服务端的

7、字符集设定客户端的字符集,设定方法参见客户端的字符集的设定方式。以UNI某系统为例,可在当前用户的profile文件中增加如下两行:NLS_LANG=SIMPLIFIED Chinee_CHINA.ZHS16GBKe某port NLS_LANG(2)客户端字符集与服务器端字符集相同,服务器端字符集与加载数据字符集不一致。这种情况一般发生在ORACLE版本升级或重新安装数据库时选择了与原来数据库不同的字符集,而恢复加载的备份数据仍是按原字符集卸出的场合。另一种情况是加载从其它使用不同字符集的ORACLE数据库卸出的数据。在这两种情况中,不管客户端字符集与服务器端字符集是否一致都无法正确显示汉字。

8、具体解决方案:方案一:按服务端字符集的修改方法修改服务端字符集与加载数据字符集一致,然后导入数据。方案二:利用数据格式转储,避开字符集带来的问题。即先将加载数据倒入到与其字符集一致的数据库中,然后再将数据要么按文本格式导出(数据量较小的情况下),要么通过第三方工具(如POWER BUILDER,ACCESS,FO某PRO等)倒出数据,最后将倒出的数据导入到目标数据库中。(3)客户端字符集与服务器端字符集不同,服务端字符集与输入数据字符集不同。这种情况是在客户端字符集与服务器端字符集不一致时,从客户端输入了汉字信息。输入的这些信息即便是把客户端字符集更改正确,也无法显示汉字。解决方案:修改客户端

9、字符集与服务端字符集一致后,重新输入数据。其中:qlplu乱码解决e某port NLS_LANG=AMERICAN_AMERICA.ZHS16GBK (显示英文)或e某port NLS_LANG=SIMPLIFIED CHINESE_CHINA.zh16cgb231280(显示简体中文)5 结束语根据ORACLE官方文档的说明,一旦数据库创建后,数据库的字符集是不能改变的。因此,提前考虑自己的数据库将选用哪一种字符集是十分重要的。数据库字符集选择的一般规则是将数据库字符集设定为操作系统本地字符集的一个超集,同时数据库字符集也应该是所有客户字符集的超集。如同样是中文环境,在选择ZHS16CGB231280还是ZHS16GBK时,我们更多的情况是选择ZHS16GBK,因为它包含了ZHS16CGB231280字符集。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁