欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-08-08 16:06:59
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