您的位置:首页 > 其它

varchar2(n)与varchar2(n char)的区别

2016-04-14 20:31 211 查看
在oracle中varchar2(n)与varchar2(n char)的主要区别就是所占用的存储空间不同。

举个栗子:

如下sql创建两张表



发现创建完后他们的数据长度是不同的,varchar2(2 char)的字段占用了8个字节,而varchar2(2)只占了两个字节。后google发现varchar2(n)所占具体字节数与NLS_LENGTH_SEMANTICS这个参数有关,默认情况下varchar2(2) <==> varchar2(2 bytes), 因为NLS_LENGTH_SEMANTICS的默认值为byte。



接下来我们修改NLS_LENGTH_SEMANTICS的值,在创建表test3,一切困惑就都解开了。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: