首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有NVARCHAR2字符集的AL32UTF8数据库中的AL32UTF8数据类型

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

Stack Overflow用户
提问于 2015-01-13 23:38:23
回答 1查看 966关注 0票数 1

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

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

谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-01-14 00:16:34

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

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

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27933519

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档