日期:2014-05-16  浏览次数:20346 次

理解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
的字符集命名遵循以下命名规则:
??? <Language><bit size><encoding>
???
: <语言><比特位数><编码
>
???
比如: 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-16unicode16位编码方式,是一种定长多字节编码,用2个字节表示一个unicode字符,AF16UTF16UTF-16编码字符集。
??? UTF-8
unicode8位编码方式,是一种变长多字节编码,这种编码可以用123个字节表示一个unicode字符,AL32UTF8UTF8UTFEUTF-8编码字符集

2.3 字符集超级
??? 当一种字符集(字符集A)的编码数值包含所有另一种字符集(字符集B)的