经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Oracle » 查看文章
mybatis + oracle,出现ORA-01461:仅能绑定要插入LONG列的LONG值
来源:cnblogs  作者:冷月寒雪  时间:2019/10/12 9:15:54  对本文有异议

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

原文链接:http://www.cnblogs.com/bindong6996/p/11654945.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号