ORA-01461:仅能绑定要插⼊LONG列的LONG值
感谢原作者:
检查插⼊的值是否⼤于该字段数据类型约束的长度。
这个异常是指,⽤户向数据库执⾏插⼊数据操作时,某条数据的某个字段值过长,如果是varchar2类型的,当长度超过2000,--4000(最⼤值)之间的时
候,oracle会⾃动将该字段值转为long型的,然后,插⼊操作失败。解决办法是:将此字段的类型改为clob或者blob类型;
但是将oracle数据库表中的varchar2类型直接改成clob类型会失败,解决办法如下:new ⼀个Sql view,执⾏下列代码:
alter table A modify column_a long;
alter table A modify column_a clob;
在进⾏此操作之前需要清空表中的数据,请提前备份数据,修改完成后,将数据导⼊即可。
注:clob不需指定长度。
1、插⼊到字符串长度⼤于4000字节
2、插⼊到表中的记录其中⼀个是long类型、还有其他实际长度⼤于2000个字节(如果是UTF-8,则是1333个字节);或者是插⼊的记录中有两个或两个以上长度⼤于2000字节的字符串。
⽤以下SQL可以查出有可能引起ORA-01461错误的表:
SELECT*FROM
(SELECT TABLE_NAME, OWNER, count(*) NUM
FROM DBA_TAB_COLUMNS
字符串长度和字节
WHERE DATA_TYPE='LONG'
OR (( DATA_TYPE='VARCHAR2'
or DATA_TYPE='CHAR'
or DATA_TYPE='NVARCHAR2'
or DATA_TYPE='NCHAR')
AND DATA_LENGTH >1333)
AND OWNER NOT IN
('SYS','SYSTEM','SH','OLAPSYS','MDSYS','WKSYS','ODM','XDB','WMSYS')
GROUP BY TABLE_NAME, OWNER)
WHERE NUM >1
关于错误的其他原因
当向ORACLE数据库中插⼊或更新数据时,报错“ORA-01461: 仅可以为插⼊ LONG 列的 LONG 值赋值”,可能有以下⼏种原因:
1、插⼊到字符串长度⼤于4000字节。
2、插⼊到表中的记录的某个字段数据的实际长度⼤于2000个字节(如果是UTF-8,则是1333个字节);或者是插⼊的记录中有两个或两个以上长度⼤于2000字节的字符串。
3、数据库与客户端的JDBC驱动不匹配。
对于UTF-8或欧洲的某些字符集,oracle在存储时,对于⼀个字符需要2个或3个字节的存储空间,虽然表定义中为varchar2(4000),但是其实该字段的
data_length为其2倍或3倍长。这种情况下oracle会把data_length长度超过4000的当做LONG型处理,你的表中有两个这样的字段,插⼊数据时相当于同时操作2个LONG字段。
最近在项⽬中仅常遇到,在这家客户那⾥邮件发送没问题,可是跑到另外⼀家客户那⾥缺发不出去,觉得很奇怪,通过⼀番折腾之后,把问题落在了Oracle JDBC Driver上,因为在客户现场,⽤的oracle版本不统⼀,有些客户使⽤的是oracle9i,有些使⽤的是Oracle10g,但是项⽬中同意使⽤了ojdbc14.jar做为驱动,那当然就有问题了,以下列出在2个驱动之间的区别:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。