关于clob字段的使用 "ORA-22835:缓冲区对于CLOB到CHAR转换而言太小"异常
来源:互联网 发布:spss数据信度分析 编辑:程序博客网 时间:2024/06/05 23:21
版权声明:本文为博主原创文章,未经博主允许不得转载。
在日常开发中,经常遇到存储字段大于4000字节的情况,这时候,就要考虑到clob字段了,而最长见的异常就是 "ORA-22835:缓冲区对于CLOB到CHAR转换而言太小"了,那么该如何解决呢???
创建表
CREATE TABLE clobtest( id NUMBER(19) not null, text_max CLOB)
插入内容sql
INSERT INTO clobtest(ID,text_clob) VALUES (#{id} ,#{str,jdbcType=CLOB})
查看内容sql
select text_clob from clobtestwhere id=#{0}
mapper层此处省略... ...
测试类
测试插入
@Testpublic void testInsert(){try {StringBuilder sb = new StringBuilder();for (int i = 0; i <30000; i++) {sb.append(i+",");}String str = sb.toString(); //插入数据库int a = gbossInvokeMapper.testInsert(str);System.out.println(a);} catch (Exception e) {e.printStackTrace();}}
测试查询
如果用to_char去转换的话,则可能出现"ORA-22835:缓冲区对于CLOB到CHAR转换而言太小"异常
select to_char(text_clob) text_clob from clobtestwhere id=#{0}//不可用
解决方案
@Testpublic void textRead(){try {String reString = "";//读取数据库内容Map<String, Object> map = gbossInvokeMapper.textRead();ClobProxyImpl c = (ClobProxyImpl)map.get("TEXT_MAX");Reader r = c.getCharacterStream();BufferedReader br = new BufferedReader(r); String s = br.readLine(); StringBuffer sb = new StringBuffer(); while (s != null) {// 执行循环将字符串全部取出付值给StringBuffer由StringBuffer转成STRING sb.append(s); s = br.readLine(); } reString = sb.toString(); if(br!=null){ br.close(); } if(r!=null){ r.close(); } System.out.println(reString);} catch (Exception e) {e.printStackTrace();}System.out.println("over");}
阅读全文
0 0
- 关于clob字段的使用 "ORA-22835:缓冲区对于CLOB到CHAR转换而言太小"异常
- ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小
- ORA-22835:缓冲区对于CLOB到CHAR转换而言太小
- oracle clob字段 to_char() 缓冲区太小
- ORA-22835 缓冲区太小
- 两个读写clob字段的小过程
- 关于 Oracle Clob Blob 字段的读写
- CLOB字段超4000报ORA-22835或ORA-01704
- CLOB字段的修改
- clob字段的显示
- Hibernate 中Clob字段的使用
- Hibernate中Clob字段的使用
- oracle中clob字段的使用
- 在TOMCAT中,以jndi方式操作clob字段时,类型转换异常的对策
- Oracle 插入CLOB字段的简易写法(纯脚本操作插入到CLOB字段)
- hibernate 关于 Clob使用
- clob字段使用union问题
- oracle.sql.CLOB不能转换成oracle.sql.CLOB类型的异常 java.lang.ClassCastException: oracle.sql.CLOB
- 好的学习网站推荐
- 微信抢红包应用要哭了,让我们来给微信红包设计一个新交互
- 【YDKJS笔记】二、作用域与闭包
- mysql的order by自定义排序
- JavaScript之路(3)JavaScript的函数
- 关于clob字段的使用 "ORA-22835:缓冲区对于CLOB到CHAR转换而言太小"异常
- Multiframe CONNECT Edition v21.10.00.39 Win64 1CD
- 关于adapter 多次打印getView问题,解决方案
- 第五周【项目2
- 为什么互联网公司不开除测试工程师?
- 646. Maximum Length of Pair Chain
- Java四种引用包括强引用,软引用,弱引用,虚引用
- Ajax工作原理
- 第五周 【项目1