数据大小超出此类型的最大值; 解决办法
来源:互联网 发布:兼职平台 知乎 编辑:程序博客网 时间:2024/04/29 02:20
一、异常情况:
有了一定Java编程经验之后,一般都使用PreparedStatement代替Statement。
但实际开发中对数据库进行操作时,字段遇到大数据并且该字段为非BLOB,CLOB的类型时,若采用PreparedStatement方法setString方法时会如下异常: java.sql.SQLException: 数据大小超出此类型的最大值
实际数据库定义字段长度为:4000,而包装的数据内容长度只有1000左右
二、分析原因:
1、驱动程序在把SQL语句发给数据库前,PreparedStatement对字符串进行预处理并进行了转义替换;
2、字符集原因。
三、解决办法:
通过阅读PreparedStatement文档,setCharacterStream方法可以解决这个问题:
stmt.setCharacterStream(1,
new InputStreamReader(String内容, String内容.length());
四、案例总结:
JDBC在转换过程中对字符串的长度做了限制。这个限制和数据库中字段的实际长度没有关系。而setCharacterStream()方法可以逃过字符转换限制,也就成为了解决此问题的方案之一。JDBC对转换字符长度的限制是为了转换过程中的数据扩展。根据实际测试结果,在ZHS16GBK字符集和thin驱动下,2000-4000长度的varchar字段都只能插入1333个字节(约666个汉字)。
故解决PreparedStatement的setString中字符串长度问题可以有两种办法:
1、使用setCharacterStream()方法;
2、使用OCI驱动连接Oracle数据库。
有了一定Java编程经验之后,一般都使用PreparedStatement代替Statement。
但实际开发中对数据库进行操作时,字段遇到大数据并且该字段为非BLOB,CLOB的类型时,若采用PreparedStatement方法setString方法时会如下异常: java.sql.SQLException: 数据大小超出此类型的最大值
实际数据库定义字段长度为:4000,而包装的数据内容长度只有1000左右
二、分析原因:
1、驱动程序在把SQL语句发给数据库前,PreparedStatement对字符串进行预处理并进行了转义替换;
2、字符集原因。
三、解决办法:
通过阅读PreparedStatement文档,setCharacterStream方法可以解决这个问题:
stmt.setCharacterStream(1,
new InputStreamReader(String内容, String内容.length());
四、案例总结:
JDBC在转换过程中对字符串的长度做了限制。这个限制和数据库中字段的实际长度没有关系。而setCharacterStream()方法可以逃过字符转换限制,也就成为了解决此问题的方案之一。JDBC对转换字符长度的限制是为了转换过程中的数据扩展。根据实际测试结果,在ZHS16GBK字符集和thin驱动下,2000-4000长度的varchar字段都只能插入1333个字节(约666个汉字)。
故解决PreparedStatement的setString中字符串长度问题可以有两种办法:
1、使用setCharacterStream()方法;
2、使用OCI驱动连接Oracle数据库。
- 数据大小超出此类型的最大值; 解决办法
- 数据大小超出此类型的最大值
- 数据大小超出此类型的最大值
- 数据大小超出此类型的最大值
- Oracle 17070:数据大小超出此类型的最大值
- java.sql.SQLException: 数据大小超出此类型的最大值
- PreparedStatem: 数据大小超出此类型的最大值
- 解决Mybatis框架java.sql.SQLException: 数据大小超出此类型的最大值的问题
- 关于“Hibnerate报数据大小超出此类型的最大值”问题【已解决】
- ORACLE当遇到“数据大小超出此类型的最大值”和“仅可以为插入 LONG 列的 LONG 值赋值”异常时的解决方法
- 整数数据运算超出最大值
- json序列化数据超出最大值(maxJsonLength)
- [SQLServer]复制与订阅 要复制的LOB数据的长度超出了配置的最大值
- 关于任意数字类型的数组求最大值解决办法
- 堆大小的最大值
- ORA-00059: 超出 DB_FILES 的最大值
- ORA-00059: 超出 DB_FILES 的最大值
- ORA-00059 超出 DB_FILES 的最大值
- Myeclipse8.5 反编译插件 jad 安装
- php-Arrays 函数-array_rand-从数组中随机取出一个或多个单元
- android中的Notification使用
- eclipse java.lang.OutOfMemoryError: Java heap space 解决方案
- 清空浏览器缓存
- 数据大小超出此类型的最大值; 解决办法
- Java中的换行符
- S3C2440 UATR的学习
- zend framework 重定向方法(render, forward, redirect)总结
- 海量数据高性能分页
- Android Handler 异步消息机制
- 互联网骨干网
- 如何关闭windows 2003浏览网页时信任站点添加提示以及解决不能加入可信任的站点
- 基于Dojo的简单IDE编辑器----DOM浏览器上的实现