具有 AL32UTF8 字符集的 Oracle 数据库中的 NVARCHAR2 数据类型

NVARCHAR2 data types in an Oracle database with AL32UTF8 character set

我继承了一个 Oracle 11g 数据库,其中包含许多包含 NVARCHAR2 列的表。

如果数据库已经有AL32UTF8字符集,是否需要NVARCHAR2数据类型来存储Unicode,如果没有,是否可以将这些列转换为VARCHAR2

谢谢。

如果数据库字符集是 AL32UTF8VARCHAR2 列将存储 Unicode 数据。最有可能的是,这些列应该转换为 VARCHAR2.

假设国家字符集是AL16UTF16,这是数据库字符集已经支持Unicode时默认的也是唯一合理的国家字符集,有可能选择使用NVARCHAR2 是故意的,因为 UTF-16 编码有一些好处。例如,如果这些列主要存储日文或中文数据,UTF-16 通常会为每个字符使用 2 个字节的存储空间,而不是 UTF-8 中的 3 个字节。可能还有其他原因使人们更喜欢一种 Unicode 编码而不是另一种可能在这里发挥作用的原因。但是,大多数时候,人们在支持 Unicode 的数据库中创建 NVARCHAR2 列是无意的,并不是因为他们对不同 Unicode 编码的好处进行了全面分析。