`
guohf
  • 浏览: 419226 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值

阅读更多

--- The error occurred in ibatis/SqlMap/sql-System.xml. 
--- The error occurred while applying a parameter map. 
--- Check the mod.info.insert-InlineParameterMap. 
--- Check the statement (update failed). 
--- Cause: java.sql.SQLException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:  
--- The error occurred in ibatis/SqlMap/sql-System.xml. 
--- The error occurred while applying a parameter map. 
--- Check the mod.info.insert-InlineParameterMap. 
--- Check the statement (update failed). 
--- Cause: java.sql.SQLException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值

初步怀疑是插入的值大于该字段数据类型约束的长度导致。因为这个异常是指用户向数据库执行插入数据操作时,某条数据的某个字段值过长,如果是varchar2类型(最大长度为4000字节)的,当长度超过2000--4000(最大值)之间的时候,oracle会自动将该字段值转为long型的,插入操作失败。

解决办法是:将此字段的类型改为clob或者blob类型;

但是将oracle数据库表中的varchar2类型直接改成clob类型会失败,解决办法如下:new 一个Sql view,执行下列代码:

alter table table_name modify col_name long;
alter table table_name modify col_name 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','ORDSYS','CTXSYS','ODM','XDB','WMSYS','APEX_030200','EXFSYS','SYSMAN','ORDDATA')
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字段。

分享到:
评论

相关推荐

    ORA-01461 仅可以为插入 LONG 列的 LONG 值赋值”解决办法

    ORA-01461 错误是 Oracle 数据库中的一种常见错误,错误信息为“仅可以为插入 LONG 列的 LONG 值赋值”。该错误通常是由于 Oracle 的 jar 包版本与 Oracle 数据库实际版本不匹配造成的。 在了解 ORA-01461 错误解决...

    CLOB 字段类型报错 ORA-01704: 文字字符串过长的解决

    而对于CLOB类型,虽然没有硬性长度限制,但一次PL/SQL语句中的绑定变量值不能超过4000个字符。 在处理这类问题时,有几种常见的解决方案: 1. **分块插入**: 当你的数据长度超过了4000个字符,你可以选择分批...

    oracle错误报告.docx

    例如,CHAR和RAW类型的字段长度不能超过2000,而其他类型如VARCHAR2或LONG则允许更长的长度。解决方法是缩短字段长度或改变数据类型。 2. ORA-00911: 无效字符。此错误表明标识符的起始字符或包含不允许的字符。...

    cms后台管理

    private static final long serialVersionUID = 1L; private Integer id; private String title; private String content; public MyContent () { super(); } ……get set方法 } 接下来是配置hibernate中jc...

    Oracle的CLOB大数据字段类型操作方法

    例如,直接插入一个长字符串会因超出VARCHAR2的限制而失败,报 ora-01704 错误。正确的方法是使用PL/SQL的绑定变量技术,如下所示: ```sql DECLARE V_LANG CLOB := '待插入的海量字符串'; V_UPDATE CLOB := '...

    Loadrunner-oracle连接/修改update/select用例

    //设定保存列中的某个数据到row中,第二个参数为第几列,第三个参数为第几行(只能保存一个值),最后一个参数就是你想要保存到的parameter名称 lrd_ora8_save_col(OraStm1, 1, 1, 0, "result"); //这个遍历刚才查询...

    RHEL5_Oracle_RAC

    - **系统位数确认**:通过`getconf LONG_BIT`命令确认操作系统位数,以匹配软件要求。 - **分区管理**:考虑主分区和逻辑分区的数量限制,优化存储布局。 综上所述,RHEL5_Oracle_RAC的部署不仅涉及到复杂的软件...

    ORACLE 8-8I开发使用手册

    1. **数据库安装与配置**:在Oracle 8-8i中,安装过程涉及创建数据库实例、设置网络服务和配置初始化参数文件(init.ora)。管理员需要熟悉SQL*Plus工具来执行这些任务。 2. **数据类型**:Oracle 8-8i支持多种数据...

    Oracle9i基础

    2. **数据库安装与配置**:学习Oracle9i基础包括了解如何在不同操作系统上安装数据库软件,设置初始化参数文件(init.ora),创建数据库实例,并进行网络配置,例如通过Net8或后来的Oracle Net Services。...

    OTL使用指南

    - **OTL_STREAM的主要方法**:这一部分涵盖了如何使用OTL_STREAM进行数据的读写操作,包括设置流缓冲区大小、数据绑定、变量的动态绑定和常量SQL的使用等。 - **OTL_CONNECT的主要方法**:介绍了如何通过OTL_...

Global site tag (gtag.js) - Google Analytics