ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值 数据库插入的数据长度过长引起无法插入数据
2010-10-28 15:52
1126 查看
转自:http://blog.163.com/zhchf_52@yeah/blog/static/67822974201081710812218/
检查插入的值是否大于该字段数据类型约束的长度。
这个异常是指,用户向数据库执行插入数据操作时,某条数据的某个字段值过长,如果是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个驱动之间的区别:
1.oracle10g中将中文字符解析为3个字节,oracle9i中保留为2个字节,在插入时常常会因为这个问题而造成数据插入失败、超常
2.在处理大字符集的时候,同样存在字符限制,class12只能支持到3000左右吧,ojdbc14可以支持到更长
http://hikin.javaeye.com/blog/548945
oracle 10g 几个版本jdbc驱动下载
文章分类:数据库
为了避免开发中不必要的麻烦,推荐用最新的版本 Oracle 10g 10.2.0.4 JDBC_classes12.jar
如新的版本 可以解决 c3p0的警告和MyEclipse hibernate生成文件等问题
org.hibernate.exception.GenericJDBCException: Could not get list of tables from database. Probably a JDBC driver problem.
Oracle_10g_10.2.0.4_JDBC_classes12.jar
(1.5 MB)
Oracle_10g_10.2.0.4_JDBC_ojdbc14.jar
(1.5 MB)
Oracle_10g_10.1.0.2_JDBC_classes12.jar
(1.4 MB)
Oracle_10g_10.1.0.2_JDBC_ojdbc14.jar
(1.3 MB)
另外:java中String的getLength()方法得到的是此字符串的长度。长度等于字符串中16位Unicode 字符数
,不是该字符串的字节
数。得到该字符传字节长度的方法是string.getBytes().length
检查插入的值是否大于该字段数据类型约束的长度。
这个异常是指,用户向数据库执行插入数据操作时,某条数据的某个字段值过长,如果是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个驱动之间的区别:
1.oracle10g中将中文字符解析为3个字节,oracle9i中保留为2个字节,在插入时常常会因为这个问题而造成数据插入失败、超常
2.在处理大字符集的时候,同样存在字符限制,class12只能支持到3000左右吧,ojdbc14可以支持到更长
http://hikin.javaeye.com/blog/548945
oracle 10g 几个版本jdbc驱动下载
文章分类:数据库
为了避免开发中不必要的麻烦,推荐用最新的版本 Oracle 10g 10.2.0.4 JDBC_classes12.jar
如新的版本 可以解决 c3p0的警告和MyEclipse hibernate生成文件等问题
org.hibernate.exception.GenericJDBCException: Could not get list of tables from database. Probably a JDBC driver problem.
Oracle_10g_10.2.0.4_JDBC_classes12.jar
(1.5 MB)
Oracle_10g_10.2.0.4_JDBC_ojdbc14.jar
(1.5 MB)
Oracle_10g_10.1.0.2_JDBC_classes12.jar
(1.4 MB)
Oracle_10g_10.1.0.2_JDBC_ojdbc14.jar
(1.3 MB)
另外:java中String的getLength()方法得到的是此字符串的长度。长度等于字符串中16位Unicode 字符数
,不是该字符串的字节
数。得到该字符传字节长度的方法是string.getBytes().length
相关文章推荐
- ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值===ORACLE VARCHAR2最大长度问题
- NHibernate 处理 oracle 的long数据类型(ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值)
- (Clob的写入和读取-java)更新数据库报错:SQL Error: 1461, SQLState: 72000 ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- ORA-01461:仅能绑定要插入 LONG 列的 LONG 值
- ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- Oracle中Clob类型处理解析(NHibernate long值绑定long列,或者是直接oraclecommand的插入的时候报错都能用,ORA-01461:仅可以插入LONG列的LONG值赋值
- ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- Cause: java.sql.SQLException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- java.sql.SQLException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值;ORACLE数据库异常解决办法
- 关于导入数据库dmp时遇到的错误 “ORA-01461: 仅可以为插入 LONG 列的 LONG 值赋值”
- VS报错:Oracle.ManagedDataAccess.Client.OracleException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- java.sql.SQLException: ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值;ORACLE数据库异常解决办法
- mybatis + oracle insert clob,出现ORA-01461:仅能绑定要插入LONG列的LONG值
- ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- 转----Oracle中Clob类型处理解析(NHibernate long值绑定long列,或者是直接oraclecommand的插入的时候报错都可以用,ORA-01461:仅可以插入LONG列的LONG值赋值)
- ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值
- 出现ORA-01461:仅能绑定要插入LONG列的LONG值 mybatis+orcale
- ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值