前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小

ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小

作者头像
星哥玩云
发布2022-08-17 20:27:49
3.1K0
发布2022-08-17 20:27:49
举报
文章被收录于专栏:开源部署开源部署

前言

做项目的时候遇到一个报错:ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小。查找原因发现是某个字段在数据库中是clob类型。然后sql语句进行查询的时候,对该字段进行了to_char操作。由于varchar类型最大长度为4000,而clob中的内容长度高于4000。于是产生这样的问题。针对这个问题,结合自己的测试,想了以下三种解决方法,在此进行记录。

一、进行实体映射及获取字段数据时,直接当成string处理

比如说,我们使用jdbctemplate来进行查询的时候,封装实体对象字段,我们不将字段封为clob类型而是直接封为string类型。然后我们进行查询的时候,会发现没有问题,clob中的内容完整的封入了string字段中。

二、对clob进行截取

数据库中的clob字段的内容进行截取,也可以解决这一问题,但是会造成clob中内容获取的不完整。

比如下方 name字段是clob类型,sql写法如下:

select to_char(substr(name,0,4000)) as name from people

我们截取name的前4000位,这样没有超过varchar类型的最大值,所以不会报错。

需要注意的是:如果clob中有中文会占两个字符。所以比较安全的方式就是除以2,进行截取。

sql写法如下:

select to_char(substr(name,0,2000)) as name from people

三、通过java代码将clob转为string

我们获取到一个clob类型的数据后,对其进行处理,使其转换为string类型。

转换代码如下:

    public String ClobtoString(Clob clob){         String reString = "";         Reader is = null;         try {             is = clob.getCharacterStream();         } catch (Exception e) {             e.printStackTrace();         }         // 得到流         BufferedReader br = new BufferedReader(is);         String s = null;         try {             s = br.readLine();         } catch (Exception e) {             e.printStackTrace();         }         StringBuffer sb = new StringBuffer();         while (s != null) {             // 执行循环将字符串全部取出付值给StringBuffer由StringBuffer转成STRING             sb.append(s);             try {                 s = br.readLine();             } catch (Exception e) {                 // TODO Auto-generated catch block                 e.printStackTrace();             }         }         reString = sb.toString();         return reString;     } 

总结

三种方式,推荐大家使用第三种。

第三种方式正规,靠谱。

第二种方式,如果图便捷,又对数据完整性没要求,可以使用。

第一种方式,只在spring中的jdbcTemplate下使用没有发现问题,其他操作方式或数据库框架可能引起问题,需要大家来测试了。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档