mybatis + oracle,出现ORA-01461:仅能绑定要插入LONG列的LONG值
程序员文章站
2022-05-03 15:03:52
1.这个异常是指,用户向数据库执行插入数据操作时,某条数据的某个字段值过长,如果是varchar2类型的,当长度超过2000,--4000(最大值)之间的时候,oracle会自动将该字段值转为long型的(-_-||有点坑~),然后插入操作失败。 2.改完数据类型之后还是报这个错,原因是:当从dua ......
1.这个异常是指,用户向数据库执行插入数据操作时,某条数据的某个字段值过长,如果是varchar2类型的,当长度超过2000,--4000(最大值)之间的时候,oracle会自动将该字段值转为long型的(-_-||有点坑~),然后插入操作失败。
2.改完数据类型之后还是报这个错,原因是:
当从dual中取数据时,会将clob对象的字段转为long型,所以mybatis里不能用select xxxx from dual union all的方式。而且mybatis里要这样写:jdbctype=clob
另外提一下,之前不想在代码的getter里写一堆截取字符长度的代码,就想利用oracle数据库的substrb函数。
substrb是在插入的时候进行截取,但这个时候按照1的说法已经把超长字段的类型改为long类型,所以还是会报错。
解决办法:要么是在赋值的时候就截断好不能超长,要么是把超长字段的类型改为clob或者blob类型
参考资料:
https://www.cnblogs.com/xiaotiannet/p/3846444.html
https://www.cnblogs.com/xiaoliu66007/p/8384519.html
下一篇: Oracle数据库创建只读用户