在Oracle Database 12c中,我们可以为varchar2、nvarchar2和RAW数据类型指定32767 bytes 的最大长度了, 以便用户将更长的字符串存储在数据库中。
在12c之前的版本中,varchar2和nvarchar2数据类型的最大长度是4000 bytes,而raw是2000 bytes。
varcha2、nvarchar2和raw字段的定义长度将影响字段的内部存储方式
- 定义为4000字节或更小的varchar2、nvarchar2以及2000字节或更小的raw字段,将被inline存放
- 定义为4000字节以上的varchar2、nvarchar2以及2000字节以上的raw字段的话,被称作extended character data type columns,以out of line方式存储。
参数MAX_STRING_SIZE控制扩展数据类型extended data type的最大长度:
- STANDARD 代表12c之前的长度限制,即varchar2、nvarchar2 4000 bytes, raw 是2000 bytes
- EXTENDED 代表12c 32k strings新特性,varchar2、nvarchar2、raw最大长度32k bytes
Extended character data types 扩展字符类型存在以下的限制:
- 不支持cluster table 簇表和index-organized tables索引组织表
- 不支持intrapartition的并行DDL、UPDATE和DELETE DML
- 不支持在Automatic Segment Space Management (ASSM)表空间上的intrapartition parallel direct-path inserts