NVARCHAR(MAXSIZE)

本文探讨了在Oracle数据库中使用NVARCHAR2类型字段时遇到的问题,特别是当字段长度设置为3000时出现的建表失败情况。通过查询官方文档及v$nls_parameters视图,明确了不同字符集下NVARCHAR2的最大长度限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

昨日上线个表 其中好多NVARCHAR2字段 其中一个设置了3000 结果无法建表. 虽然在开发库OK

  SH_REMARK            NVARCHAR2(3000),

官方文档如此说

The maximum column size allowed is 4000 characters when the national character set is UTF8 and 2000 when it is AL16UTF16. The maximum length of an NVARCHAR2 column in bytes is 4000.

意思是 如果国家字符集是UTF8 那就是4000 如果是UTF16那是2000  BYTES总大小4000 


SQL> select * from v$nls_parameters where parameter like 'NLS%';
 
PARAMETER                                                        VALUE
---------------------------------------------------------------- ----------------------------------------------------------------
NLS_LANGUAGE                                                     AMERICAN
NLS_TERRITORY                                                    AMERICA
NLS_CURRENCY                                                     $
NLS_ISO_CURRENCY                                                 AMERICA
NLS_NUMERIC_CHARACTERS                                           .,
NLS_CALENDAR                                                              GREGORIAN
NLS_DATE_FORMAT                                                         DD-MON-RR
NLS_DATE_LANGUAGE                                                   AMERICAN
NLS_CHARACTERSET                                                      AL32UTF8
NLS_SORT                                                                            BINARY
NLS_TIME_FORMAT                                                            HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT                                                DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT                                                      HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT                                          DD-MON-RR HH.MI.SSXFF AM TZR
NLS_DUAL_CURRENCY                                                   $
NLS_NCHAR_CHARACTERSET                                      AL16UTF16
NLS_COMP                                                                           BINARY
NLS_LENGTH_SEMANTICS                                             BYTE
NLS_NCHAR_CONV_EXCP                                              FALSE

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值