重庆思庄Oracle、Redhat认证学习论坛

标题: Oracle 字符 Character [打印本页]

作者: jiawang    时间: 2023-11-14 16:35
标题: Oracle 字符 Character

1 字符集

实质就是按照一定的字符编码方案,对一组特定的符号,分别赋予不同数值编码的集合。Oracle数据库最早支持的编码方案是US7ASCII。Oracle的字符集命名遵循以下命名规则:

     <Language><bitsize><encoding>

     即:<语言><比特位数><编码>

比如:ZHS16GBK表示采用GBK编码格式、16位(两个字节)简体中文字符集。


2 字符编码方案

2.1 单字节编码

   (1)单字节7位字符集,可以定义128个字符,最常用的字符集为US7ASCII

   (2)单字节8位字符集,可以定义256个字符,适合于欧洲大部分国家

     例如:WE8ISO8859P1(西欧、8位、ISO标准8859P1编码)


2.2  多字节编码

(1)变长多字节编码

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

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

(2)定长多字节编码

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


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.4 字符集超级

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


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





欢迎光临 重庆思庄Oracle、Redhat认证学习论坛 (http://bbs.cqsztech.com/) Powered by Discuz! X3.2