【问题标题】:NVARCHAR2 data types in an Oracle database with AL32UTF8 character set具有 AL32UTF8 字符集的 Oracle 数据库中的 NVARCHAR2 数据类型
【发布时间】:2015-01-13 23:38:23
【问题描述】:

我继承了一个 Oracle 11g 数据库,该数据库有许多带有NVARCHAR2 列的表。

如果数据库已经有AL32UTF8 字符集,那么NVARCHAR2 数据类型是存储Unicode 所必需的吗?如果没有,这些列是否可以转换为VARCHAR2

谢谢。

【问题讨论】:

    标签: oracle11g


    【解决方案1】:

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

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

    【讨论】:

    • 一个非常好的、及时和全面的答案。谢谢。
    猜你喜欢
    • 2015-04-30
    • 2010-12-16
    • 1970-01-01
    • 1970-01-01
    • 2012-09-04
    • 1970-01-01
    • 1970-01-01
    • 2018-07-23
    • 2011-02-16
    相关资源
    最近更新 更多