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

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 781|回复: 0
打印 上一主题 下一主题

[Oracle] Oracle 字符 Character

[复制链接]
跳转到指定楼层
楼主
发表于 2023-11-14 16:35:03 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

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的超集。   
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 支持支持 反对反对
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|重庆思庄Oracle、Redhat认证学习论坛 ( 渝ICP备12004239号-4 )

GMT+8, 2024-5-2 20:22 , Processed in 0.087656 second(s), 20 queries .

重庆思庄学习中心论坛-重庆思庄科技有限公司论坛

© 2001-2020

快速回复 返回顶部 返回列表