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的超集。
|