varchar2改为clob的解决步骤
由于在后台项目建表是考虑不周全,导致列的类型选择错误,现需要修改列的类型。
一.varchar2改为clob
二.oracle中Blob和Clob类型的区别
1.BLOB
BLOB全称为二进制大型对象(Binary Large Object)。它用于存储数据库中的大型二进制对象。可存储的最大大小为4G字节
2.CLOB
CLOB全称为字符大型对象(Character Large Object)。它与LONG数据类型类似,只不过CLOB用于存储数据库中的大型单字节字符数据块,不支持宽度不等的字符集。可存储的最大大小为4G字节
通常像图片、文件、音乐等信息就用BLOB字段来存储,先将文件转为二进制再存储进去。而像文章或者是较长的文字,就用CLOB存储,这样对以后的查询更新存储等操作都提供很大的方便。
JAVA里面对CLOB的操作
在绝大多数情况下,使用2种方法使用CLOB
1 相对比较小的,可以用String进行直接操作,把CLOB看成字符串类型即可
2 如果比较大,可以用 getAsciiStream 或者 getUnicodeStream 以及对应的 setAsciiStream 和 setUnicodeStream 即可
三.CLOB字段和varchar
如果能控制在4000个字符以内的,尽量还是用varchar2(4000 CHAR)吧 如果超过了,也只好用clob了。处理起来其实也还好,基本是在程序里面当作varchar来处理即可
超过就只能用CLOB,12C里面有32K的VARCHAR2,但是实现起来还是CLOB。 如果在CLOB里面存短文本,ORACLE还是会像VARCHAR2一样处理,不会和其他字段分开存储。
四.str绑定值的结尾null字符缺失
首先将数据长度确定出来。注意:中文占用字节长度的问题;根据字符集编码的不同,在oracle里有可能占2或者3个字节。其次查看定义的字段长度,我的字段长度为vachar2(4000),貌似varchar2最长就是4000,好奇的可以去查查这方面的问题。