oracle 字符集查看与修改

上传人:洪易 文档编号:39981037 上传时间:2018-05-21 格式:DOCX 页数:8 大小:26.78KB
返回 下载 相关 举报
oracle 字符集查看与修改_第1页
第1页 / 共8页
oracle 字符集查看与修改_第2页
第2页 / 共8页
oracle 字符集查看与修改_第3页
第3页 / 共8页
oracle 字符集查看与修改_第4页
第4页 / 共8页
oracle 字符集查看与修改_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《oracle 字符集查看与修改》由会员分享,可在线阅读,更多相关《oracle 字符集查看与修改(8页珍藏版)》请在金锄头文库上搜索。

1、oracle 字符集查看与修改字符集查看与修改oracle 字符集查看与修改原文:http:/ Oracle 字符集字符集Oracle 字符集是一个字节数据的解释的符号集合,有大小之分,有相互的包容关系。ORACLE 支持国家语言的体系结构允许你使用本地化语言来存储,处理,检索数据。它使数据库数据库工具,错误消息,排序次序,日期,时间,货币,数字,和日历自动适应本地化语言和平台。影响 Oracle 数据库字符集最重要的参数是 NLS_LANG 参数。它的格式如下: NLS_LANG = language_territory.charset它有三个组成部分(语言、地域和字符集),每个成分控制了

2、NLS 子集的特性。其中:Language:指定服务器服务器消息的语言,影响提示信息是中文还是英文Territory:指定服务器的日期和数字格式,Charset: 指定字符集。如:AMERICAN _ AMERICA. ZHS16GBK从 NLS_LANG 的组成我们可以看出,真正影响数据库字符集的其实是第三部分。所以两个数据库之间的字符集只要第三部分一样就可以相互导入导出数据,前面影响的只是提示信息是中文还是英文。二字符集的相关知识:二字符集的相关知识:2.1 字符集字符集实质就是按照一定的字符编码方案,对一组特定的符号,分别赋予不同数值编码的集合。Oracle 数据库最早支持的编码方案是

3、US7ASCII。Oracle 的字符集命名遵循以下命名规则:即: 比如: ZHS16GBK 表示采用 GBK 编码格式、16 位(两个字节)简体中文字符集2.2 字符编码方案字符编码方案2.2.1 单字节编码(1)单字节 7 位字符集,可以定义 128 个字符,最常用的字符集为 US7ASCII(2)单字节 8 位字符集,可以定义 256 个字符,适合于欧洲大部分国家例如:WE8ISO8859P1(西欧、8 位、ISO 标准 8859P1 编码)2.2.2 多字节编码(1)变长多字节编码某些字符用一个字节表示,其它字符用两个或多个字符表示,变长多字节编码常用于对亚洲语言的支持,例如日语、汉语

4、、印地语等例如:AL32UTF8(其中 AL 代表 ALL,指适用于所有语言)、zhs16cgb231280(2)定长多字节编码每一个字符都使用固定长度字节的编码方案,目前 oracle 唯一支持的定长多字节编码是 AF16UTF16,也是仅用于国家字符集2.2.3unicode 编码Unicode 是一个涵盖了目前全世界使用的所有已知字符的单一编码方案,也就是说 Unicode 为每一个字符提供唯一的编码。UTF-16 是 unicode 的 16 位编码方式,是一种定长多字节编码,用 2 个字节表示一个unicode 字符,AF16UTF16 是 UTF-16 编码字符集。UTF-8 是

5、unicode 的 8 位编码方式,是一种变长多字节编码,这种编码可以用 1、2、3 个字节表示一个unicode 字符,AL32UTF8,UTF8、UTFE 是 UTF-8 编码字符集2.3 字符集超级字符集超级当一种字符集(字符集 A)的编码数值包含所有另一种字符集(字符集 B)的编码数值,并且两种字符集相同编码数值代表相同的字符时,则字符集 A 是字符集 B 的超级,或称字符集 B 是字符集 A 的子集。Oracle8i 和 oracle9i 官方文档资料中备有子集-超级对照表(subset-superset pairs),例如:WE8ISO8859P1 是 WE8MSWIN1252 的

6、子集。由于 US7ASCII 是最早的 Oracle 数据库编码格式,因此有许多字符集是 US7ASCII 的超集,例如 WE8ISO8859P1、ZHS16CGB231280、ZHS16GBK 都是 US7ASCII 的超集。2.4 数据库字符集(数据库字符集(oracle 服务器端字符集)服务器端字符集)数据库字符集在创建数据库时指定,在创建后通常不能更改在创建后通常不能更改。在创建数据库时,可以指定字符集(CHARACTER SET)和国家字符集(NATIONAL CHARACTER SET)。2.4.1 字符集(1)用来存储 CHAR, VARCHAR2, CLOB, LONG 等类型

7、数据(2)用来标示诸如表名、列名以及 PL/SQL 变量等(3)用来存储 SQL 和 PL/SQL 程序单元等2.4.2 国家字符集:(1)用以存储 NCHAR, NVARCHAR2, NCLOB 等类型数据(2)国家字符集实质上是为 oracle 选择的附加字符集,主要作用是为了增强 oracle 的字符处理能力,因为NCHAR 数据类型可以提供对亚洲使用定长多字节编码的支持,而数据库字符集则不能。国家字符集在oracle9i 中进行了重新定义,只能在 unicode 编码中的 AF16UTF16 和 UTF8 中选择,默认值是 AF16UTF162.4.3 查询字符集参数可以查询以下数据字

8、典或视图查看字符集设置情况nls_database_parameters、props$、v$nls_parameters查询结果中 NLS_CHARACTERSET 表示字符集,NLS_NCHAR_CHARACTERSET 表示国家字符集2.4.4 修改数据库字符集按照上文所说,数据库字符集在创建后原则上不能更改。不过有 2 种方法可行。1.如果需要修改字符集,通常需要导出数据库数据,重建数据库,再导入数据库数据的方式来转换。2.通过 ALTER DATABASE CHARACTER SET 语句修改字符集,但创建数据库后修改字符集是有限制的,只有新的字符集是当前字符集的超集时才能修改数据库字

9、符集,例如 UTF8 是 US7ASCII 的超集,修改数据库字符集可使用 ALTER DATABASE CHARACTER SET UTF8。2.5 客户端字符集(客户端字符集(NLS_LANG 参数)参数)2.5.1 客户端字符集含义客户端字符集定义了客户端字符数据的编码方式,任何发自或发往客户端的字符数据均使用客户端定义的字符集编码,客户端可以看作是能与数据库直接连接的各种应用,例如 sqlplus,exp/imp 等。客户端字符集是通过设置 NLS_LANG 参数来设定的。2.5.2NLS_LANG 参数格式NLS_LANG=_.Language:显示 oracle 消息,校验,日期命

10、名Territory:指定默认日期、数字、货币等格式Client character set:指定客户端将使用的字符集例如:NLS_LANG=AMERICAN_AMERICA.US7ASCIIAMERICAN 是语言,AMERICA 是地区,US7ASCII 是客户端字符集2.5.3 客户端字符集设置方法1)UNIX 环境$NLS_LANG=“simplified chinese”_china.zhs16gbk$export NLS_LANG编辑 oracle 用户的 profile 文件2)Windows 环境编辑注册表Regedit.exe -HKEY_LOCAL_MACHINE -SOF

11、TWARE -ORACLE-HOME2.5.4NLS 参数查询Oracle 提供若干 NLS 参数定制数据库和用户机以适应本地格式,例如有NLS_LANGUAGE,NLS_DATE_FORMAT,NLS_CALENDER 等,可以通过查询以下数据字典或 v$视图查看。NLS_DATABASE_PARAMETERS:显示数据库当前 NLS 参数取值,包括数据库字符集取值NLS_SESSION_PARAMETERS: 显示由 NLS_LANG 设置的参数,或经过 alter session 改变后的参数值(不包括由 NLS_LANG 设置的客户端字符集)NLS_INSTANCE_PARAMETE:

12、显示由参数文件 init.ora 定义的参数V$NLS_PARAMETERS:显示数据库当前 NLS 参数取值2.5.5 修改 NLS 参数使用下列方法可以修改 NLS 参数(1)修改实例启动时使用的初始化参数文件(2)修改环境变量 NLS_LANG(3)使用 ALTER SESSION 语句,在 oracle 会话中修改(4)使用某些 SQL 函数NLS 作用优先级别:Sql function alter session 环境变量或注册表参数文件数据库默认参数三三EXP/IMP 与字符集与字符集3.1 EXP/IMPExport 和 Import 是一对读写 Oracle 数据的工具。Exp

13、ort 将 Oracle 数据库中的数据输出到操作系统文件中, Import 把这些文件中的数据读到 Oracle 数据库中,由于使用 exp/imp 进行数据迁移时,数据从源数据库到目标数据库的过程中有四个环节涉及到字符集,如果这四个环节的字符集不一致,将会发生字符集转换。EXP_ _ _|imp 导入文件|环境变量 NLS_LANG|-|数据库字符集|- - -四个字符集是(1)源数据库字符集(2)Export 过程中用户会话字符集(通过 NLS_LANG 设定)(3)Import 过程中用户会话字符集(通过 NLS_LANG 设定)(4)目标数据库字符集3.2 导出的转换过程在 Expo

14、rt 过程中,如果源数据库字符集与 Export 用户会话字符集不一致,会发生字符集转换,并在导出文件的头部几个字节中存储 Export 用户会话字符集的 ID 号。在这个转换过程中可能发生数据的丢失。例:如果源数据库使用 ZHS16GBK,而 Export 用户会话字符集使用 US7ASCII,由于 ZHS16GBK 是 16 位字符集,而 US7ASCII 是 7 位字符集,这个转换过程中,中文字符在 US7ASCII 中不能够找到对等的字符,所以所有中文字符都会丢失而变成“? ”形式,这样转换后生成的 Dmp 文件已经发生了数据丢失。因此如果想正确导出源数据库数据,则 Export 过程

15、中用户会话字符集应等于源数据库字符集或是源数据库字符集的超集3.3 导入的转换过程(1)确定导出数据库字符集环境通过读取导出文件头,可以获得导出文件的字符集设置(2)确定导入 session 的字符集,即导入 Session 使用的 NLS_LANG 环境变量(3)IMP 读取导出文件读取导出文件字符集 ID,和导入进程的 NLS_LANG 进行比较(4)如果导出文件字符集和导入 Session 字符集相同,那么在这一步骤内就不需要转换, 如果不同,就需要把数据转换为导入 Session 使用的字符集。可以看出,导入数据到数据库过程中发生两次字符集转换第一次:导入文件字符集与导入 Sessio

16、n 使用的字符集之间的转换,如果这个转换过程不能正确完成,Import 向目标数据库的导入过程也就不能完成。第二次:导入 Session 字符集与数据库字符集之间的转换。四四.查看数据库字符集查看数据库字符集涉及三方面的字符集,1. oracelserver 端的字符集;2. oracle client 端的字符集;3. dmp 文件的字符集。在做数据导入的时候,需要这三个字符集都一致才能正确导入。4.1 查询 oracle server 端的字符集有很多种方法可以查出 oracle server 端的字符集,比较直观的查询方法是以下这种:SQL select userenv(language) from dual;USERENV(LANGUAGE)-

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

当前位置:首页 > 研究报告 > 综合/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号