[转帖]Oracle中为什么需要NCHAR

发布时间 2024-01-09 12:03:47作者: 济南小老虎
https://zhuanlan.zhihu.com/p/668402759

 

Oracle中已经有了char、varchar2等字符类型,为什么又弄出一个nchar、nvarchar2?

Oracle数据库中有两个字符集编码,创建数据库时可以显示指定

  • 数据库字符集编码
  • 国家字符集编码
--查看当前数据库字符集和国家字符集
select * from nls_database_parameters where parameter='NLS_CHARACTERSET' OR parameter='NLS_NCHAR_CHARACTERSET';

PARAMETER	VALUE
NLS_NCHAR_CHARACTERSET	AL16UTF16 --国家字符编码为AL16UTF16
NLS_CHARACTERSET	AL32UTF8  --数据库字符编码为AL32UTF8

char、varcahr2、clob这几个类型字段存储的字符串编码类型为当前数据库字符编码,由于Oracle支持很多不同国家不同语言的字符编码,除unicode支持的几种字符编码(AL32UTF8/AL16UTF16等)外,大部分字符编码并不能表示世界上所有的字符。这就会出现一个问题,在一个数据库编码为非unicode的数据库中,如果想存储当前数据库编码不支持的字符,那是没法做到的。基于此情况出现了下面的nchar。

nchar、nvarchar2、nclob这几个类型字段存储的字符串的字符编码为国家字符集编码,且只能为unicode的AL16UTF16(默认及推荐)或者UTF-8(已弃用),由于unicode编码包含了世界所有字符,这就解决了在一个数据库编码为非unicode的数据库中,如果想存储当前数据库编码不支持的字符;

此外,由于数据库字符编码(默认AL32UTF8)和国家字符编码(AL16UTF16)不同导致的存储空间占用不同的问题,也是引入国家字符集编码的原因,AL32UTF8字符宽度为1~4字节,其中欧洲字符和中东等字符占1~2个字节,亚洲字符大部分占用3个字节,补充字符占用4个字节。而AL16UTF16字符宽度为2或4字节,其中欧洲字符、中东字符、亚洲等字符大部分都占用2个字节,补充字符占用4个字节,所以具体业务中字符类型来确定使用那种类型。