oracle字符集理解

发表于:2013-12-30来源:IT博客大学习作者:rethink点击数: 标签:oracle
oracle字符集理解: 一.引言 ORACLE数据库字符集,即Oracle全球化支持(Globalization Support),或即国家语言支持(NLS)其作用是用本国语言和格式来存储、处理和检索数据。

  oracle字符集理解:

  一.引言

  ORACLE数据库字符集,即Oracle全球化支持(Globalization Support),或即国家语言支持(NLS)其作用是用本国语言和格式来存储、处理和检索数据。利用全球化支持,ORACLE为用户提供自己熟悉的数据库母语环境,诸如日期格式、数字格式和存储序列等。Oracle可以支持多种语言及字符集,其中oracle8i支持48种语言、76个国家地域、229 种字符集,而oracle9i则支持57种语言、88个国家地域、235种字符集。由于oracle字符集种类多,且在存储、检索、迁移oracle数据时多个环节与字符集的设置密切相关,因此在实际的应用中,数据库开发和管理人员经常会遇到有关oracle字符集方面的问题。本文通过以下几个方面阐述,对oracle字符集做简要分析

  二.字符集基本知识

  2.1字符集

  实质就是按照一定的字符编码方案,对一组特定的符号,分别赋予不同数值编码的集合。Oracle数据库最早支持的编码方案是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)变长多字节编码

  某些字符用一个字节表示,其它字符用两个或多个字符表示,变长多字节编码常用于对亚洲语言的支持, 例如日语、汉语、印地语等

  例如:AL32UTF8(其中AL代表ALL,指适用于所有语言)、zhs16cgb231280

  (2)定长多字节编码

  每一个字符都使用固定长度字节的编码方案,目前oracle唯一支持的定长多字节编码是AF16UTF16,也是仅用于国家字符集

  2.2.3 unicode编码

  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)的编码数值包含所有另一种字符集(字符集B)的编码数值,并且两种字符集相同编码数值代表相同的字符时,则字符集A是字符集B的超级,或称字符集B是字符集A的子集。

  Oracle8i和oracle9i官方文档资料中备有子集-超级对照表(subset-superset pairs),例如:WE8ISO8859P1是WE8MSWIN1252的子集。由于US7ASCII是最早的Oracle数据库编码格式,因此有许多字符集是US7ASCII的超集,例如WE8ISO8859P1、ZHS16CGB231280、ZHS16GBK都是US7ASCII的超集。

  2.4 数据库字符集(oracle服务器端字符集)

  数据库字符集在创建数据库时指定,在创建后通常不能更改。在创建数据库时,可以指定字符集(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数据类型可以提供对亚洲使用定长多字节编码的支持,而数据库字符集则不能。国家字符集在oracle9i中进行了重新定义,只能在unicode编码中的AF16UTF16和UTF8 中选择,默认值是AF16UTF16

  2.4.3查询字符集参数

  可以查询以下数据字典或视图查看字符集设置情况

  nls_database_parameters、props$、v$nls_parameters

  查询结果中NLS_CHARACTERSET表示字符集,NLS_NCHAR_CHARACTERSET表示国家字符集

  2.4.4修改数据库字符集

  按照上文所说,数据库字符集在创建后原则上不能更改。如果需要修改字符集,通常需要导出数据库数据,重建数据库,再导入数据库数据的方式来转换,或通过 ALTER DATABASE CHARACTER SET语句修改字符集,但创建数据库后修改字符集是有限制的,只有新的字符集是当前字符集的超集时才能修改数据库字符集,例如UTF8是US7ASCII 的超集,修改数据库字符集可使用ALTER DATABASE CHARACTER SET UTF8。正确的修改方法如下:

  $sqlplus /nolog

  SQL>conn / as sysdba;

  若此时数据库服务器已启动,则先执行SHUTDOWN IMMEDIATE命令关闭数据库服务器,然后执行以下命令:

  SQL>STARTUP MOUNT;

  SQL>ALTER SYSTEM ENABLE RESTRICTED SESSION;

  SQL>ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;

  SQL>ALTER SYSTEM SET AQ_TM_PROCESSES=0;

  SQL>ALTER DATABASE OPEN;

  SQL>ALTER DATABASE CHARACTER SET ZHS16GBK;

  SQL>ALTER DATABASE national CHARACTER SET ZHS16GBK;

  SQL>SHUTDOWN IMMEDIATE;

  SQL>STARTUP

  2.5 客户端字符集(NLS_LANG参数)

  2.5.1客户端字符集含义

  客户端字符集定义了客户端字符数据的编码方式,任何发自或发往客户端的字符数据均使用客户端定义的字符集编码,客户端可以看作是能与数据库直接连接的各种应用,例如sqlplus,exp/imp等。客户端字符集是通过设置NLS_LANG参数来设定的。

  2.5.2 NLS_LANG参数格式

  NLS_LANG=_.

原文转自:http://blogread.cn/it/article/4654