首先须要强调下 Oracle 的数据库字符集属性会影响字符类型的容量, 能够经过执行该 sql select userenv('language') from dual;
查看 Oracle 的数据库字符集.sql
16-bit
的,那么每一个字符占16位,也就是2字节.32-bit
的,那么每一个字符占32位,也就是4字节.Tips:数据字符集不一样的状况下进行数据迁移,可能会出现长度异常的问题.数据库
示例:
char(5)
表示该字段的数据类型为char
,可存在5个字节长度的字符,不足则自动空格填充,也就是你若是存入一个字符"A",自动会在后面加上4个空格,读取出来会变成"A空格空格空格空格"编码
最大长度为4000.code
示例:
varchar2(50)
标识该字段的数据类型为varchar
,可存放单个字节长度的字符50个,好比英文/数字,但一个汉字占2个字节长度(受数据库字符集影响).ip
最大长度为2000.it
示例:
nvarchar(50)
表示该字段的数据类型为nvarchar
,可存放单个字节长度的字符50个,不论字符是汉字/英文/数字都只占1个字节长度(受数据库字符集影响).select