2022年2022年理解ORACLE数据库字符集 .pdf
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《2022年2022年理解ORACLE数据库字符集 .pdf》由会员分享,可在线阅读,更多相关《2022年2022年理解ORACLE数据库字符集 .pdf(7页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、理解 ORACLE数据库字符集一引言ORACLE 数据库字符集,即Oracle 全球化支持(Globalization Support),或即国家语言支持(NLS)其作用是用本国语言和格式来存储、处理和检索数据。利用全球化支持,ORACLE 为用户提供自己熟悉的数据库母语环境,诸如日期格式、数字格式和存储序列等。Oracle 可以支持多种语言及字符集,其中 oracle8i支持 48 种语言、76 个国家地域、229 种字符集,而 oracle9i则支持 57 种语言、88 个国家地域、235 种字符集。由于 oracle 字符集种类多,且在存储、检索、迁移 oracle数据时多个环节与字符集
2、的设置密切相关,因此在实际的应用中,数据库开发和管理人员经常会遇到有关oracle 字符集方面的问题。本文通过以下几个方面阐述,对oracle字符集做简要分析二字符集基本知识2.1 字符集实质就是按照一定的字符编码方案,对一组特定的符号,分别赋予不同数值编码的集合。Oracle 数据库最早支持的编码方案是US7ASCII。Oracle的字符集命名遵循以下命名规则:即:比如:ZHS16GBK 表示采用 GBK 编码格式、16 位(两个字节)简体中文字符集2.2 字符编码方案2.2.1 单字节编码(1)单字节 7 位字符集,可以定义 128 个字符,最常用的字符集为US7ASCII(2)单字节 8
3、 位字符集,可以定义256 个字符,适合于欧洲大部分国家例如:WE8ISO8859P1(西欧、8 位、ISO标准 8859P1编码)2.2.2 多字节编码(1)变长多字节编码某些字符用一个字节表示,其它字符用两个或多个字符表示,变长多字节编码常用于对亚洲语言的支持,例如日语、汉语、印地语等例如:AL32UTF8(其中 AL代表 ALL,指适用于所有语言)、zhs16cgb231280(2)定长多字节编码每一个字符都使用固定长度字节的编码方案,目前oracle 唯一支持的定长多字节编码是 AF16UTF16,也是仅用于国家字符集2.2.3 unicode编码名师资料总结-精品资料欢迎下载-名师精
4、心整理-第 1 页,共 7 页 -Unicode是一个涵盖了目前全世界使用的所有已知字符的单一编码方案,也就是说 Unicode 为每一个字符提供唯一的编码。UTF-16是 unicode 的 16 位编码方式,是一种定长多字节编码,用2 个字节表示一个 unicode 字符,AF16UTF16是 UTF-16编码字符集。UTF-8是 unicode 的 8 位编码方式,是一种变长多字节编码,这种编码可以用 1、2、3 个字节表示一个 unicode 字符,AL32UTF8,UTF8、UTFE 是 UTF-8编码字符集2.3 字符集超级当一种字符集(字符集A)的编码数值包含所有另一种字符集(字
5、符集B)的编码数值,并且两种字符集相同编码数值代表相同的字符时,则字符集 A是字符集 B的超级,或称字符集B是字符集 A的子集。Oracle8i和 oracle9i官方文档资料中备有子集-超级对照表(subset-superset pairs),例如:WE8ISO8859P1 是 WE8MSWIN1252的子集。由于 US7ASCII是最早的 Oracle 数据库编码格式,因此有许多字符集是US7ASCII的超集,例如 WE8ISO8859P1、ZHS16CGB231280、ZHS16GBK 都是 US7ASCII的超集。2.4 数据库字符集(oracle 服务器端字符集)数据库字符集在创建数
6、据库时指定,在创建后通常不能更改。在创建数据库时,可以指定字符集(CHARACTER SET)和国家字符集(NATIONAL CHARACTER SET)。2.4.1字符集 (1)用来存储 CHAR,VARCHAR2,CLOB,LONG等类型数据 (2)用来标示诸如表名、列名以及PL/SQL变量等 (3)用来存储 SQL和 PL/SQL程序单元等2.4.2国家字符集:(1)用以存储 NCHAR,NVARCHAR2,NCLOB等类型数据 (2)国家字符集实质上是为oracle 选择的附加字符集,主要作用是为了增强 oracle 的字符处理能力,因为NCHAR 数据类型可以提供对亚洲使用定长多字节
7、编码的支持,而数据库字符集则不能。国家字符集在oracle9i中进行了重新定义,只能在 unicode 编码中的 AF16UTF16 和 UTF8中选择,默认值是 AF16UTF16 2.4.3 查询字符集参数可以查询以下数据字典或视图查看字符集设置情况 nls_database_parameters、props$、v$nls_parameters 查询结果中 NLS_CHARACTERSET表示字符集,NLS_NCHAR_CHARACTERSET表示国家字符集2.4.4修改数据库字符集按照上文所说,数据库字符集在创建后原则上不能更改。如果需要修改字符集,通常需要导出数据库数据,重建数据库,再
8、导入数据库数据的方式来转换,或通过 ALTER DATABASE CHARACTER SET语句修改字符集,但创建数据库后修改字符集是有限制的,只有新的字符集是当前字符集的超集时才能修改数据库字符名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 7 页 -集,例如 UTF8是 US7ASCII的超集,修改数据库字符集可使用ALTER DATABASE CHARACTER SET UTF8。2.5 客户端字符集(NLS_LANG 参数)2.5.1客户端字符集含义客户端字符集定义了客户端字符数据的编码方式,任何发自或发往客户端的字符数据均使用客户端定义的字符集编码,客户端可以看作是能与
9、数据库直接连接的各种应用,例如sqlplus,exp/imp等。客户端字符集是通过设置NLS_LANG参数来设定的。2.5.2 NLS_LANG 参数格式 NLS_LANG=_.Language:显示 oracle消息,校验,日期命名 Territory:指定默认日期、数字、货币等格式 Client character set:指定客户端将使用的字符集例如:NLS_LANG=AMERICAN_AMERICA.US7ASCII AMERICAN 是语言,AMERICA 是地区,US7ASCII是客户端字符集2.5.3客户端字符集设置方法 1)UNIX环境$NLS_LANG=“simplified
10、 chinese”_china.zhs16gbk$export NLS_LANG 编辑 oracle 用户的 profile文件 2)Windows环境编辑注册表 Regedit.exe-HKEY_LOCAL_MACHINE-SOFTWARE-ORACLE HOME0 2.5.4 NLS参数查询 Oracle提供若干 NLS参数定制数据库和用户机以适应本地格式,例如有NLS_LANGUAGE,NLS_DATE_FORMAT,NLS_CALENDER等,可以通过查询以下数据字典或 v$视图查看。NLS_DATABASE_PARAMETERS-显示数据库当前 NLS参数取值,包括数据库字符集取值
11、NLS_SESSION_PARAMETERS-显示由 NLS_LANG 设置的参数,或经过alter session 改变后的参数值(不包括由NLS_LANG 设置的客户端字符集)NLS_INSTANCE_PARAMETE-显示由参数文件 init.ora 定义的参数V$NLS_PARAMETERS-显示数据库当前 NLS参数取值2.5.5修改 NLS参数使用下列方法可以修改NLS参数(1)修改实例启动时使用的初始化参数文件(2)修改环境变量NLS_LANG(3)使用 ALTER SESSION 语句,在 oracle 会话中修改名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 7
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年2022年理解ORACLE数据库字符集 2022 理解 ORACLE 数据库 字符集
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内