转载

mybatis + oracle,出现ORA-01461:仅能绑定要插入LONG列的LONG值

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

原文  https://www.maiyewang.com/2019/10/14/mybatis-oracle,出现ora-01461仅能绑定要插入long列的long值-2/
正文到此结束
Loading...