前言

做项目的时候遇到一个报错: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转成STRINGsb.append(s);try {s = br.readLine();} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}reString = sb.toString();return reString;}

总结

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

第三种方式正规,靠谱。

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

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

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

  1. oracle clob raw 转换,ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小...

    前言 做项目的时候遇到一个报错:ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小.查找原因发现是某个字段在数据库中是clob类型.然后sql语句进行查 ...

  2. ORA-22835:缓冲区对于CLOB到CHAR转换或BLOB到RAWZ转换而言太小。

    问题描述:Oracle数据库中报:缓冲区对于CLOB到CHAR转换或BLOB到RAWZ转换而言太小. 对CLOB字段进行截取,使其在TO_CHAR之前获取的数据小于4000字符,这样在进行TO_CHA ...

  3. ORA-22835:缓冲区对于CLOB到CHAR转换或BLOB到RAWZ转换而言太小

    问题描述:在使用decode函数时,提示不能里面不能用clob字段,所以用to_char转换,但是如果字符长度大于4000或汉字长度大于2000,就会报上面的错误. 解决方式1:不使用decode函数 ...

  4. ORA-64203: 目标缓冲区太小, 无法容纳字符集转换之后的 CLOB 数据

    线上遇到bug,日志显示错误ORA-64203: Destination buffer too small to hold CLOB data after character set conversi ...

  5. Oracle bug 使用max或min函数into到一个char类型报字符缓冲区太小的错误

    这个BUG出现会报错如下: selectto_char(max(RENEWAL_DATE)) intoM_YEAR_MONTH fromt_renewal_schedule; ORA-06502: P ...

  6. [转]wchar_t char std::string std::wstring CString 转换

    [转]wchar_t char std::string std::wstring CString 转换 1 #include <string> 2 // 使用CString必须使用MFC, ...

  7. CString与LPCWSTR、LPSTR、char*、LPWSTR等类型的转换【转】

    CString与LPCWSTR.LPSTR.char*.LPWSTR等类型的转换 VC++ 2010-09-25 21:23:12 阅读457 评论3   字号:大中小 订阅 一.CString与LP ...

  8. 从 char 数据类型到 datetime 数据类型的转换导致 datetime 值越界解决方案

    最近同事给一客户部署系统,最早跟我说过,时间的问题,说是显示英文日期和时间,第一反映是区域和语言那里的设置有问题,问题方法,N久后偶去客户那,竟然还是以前的问题,郁闷,回来在公司可怎么也没有试出来,倒 ...

  9. 转载:int char* float与CString 之间的转换

    <script type="text/javascript" src="http://blogger.org.cn/blog/inc/main.js"&g ...

最新文章

  1. ubutu14.04无法使用sudo,也无法切换到root用户去解决问题怎么办?
  2. linux timeline
  3. oracle专用服务器模式与共享服务器模式
  4. linux db2表死锁,记录一次问题解决:DB2死锁解决办法(SQLCODE=-911, SQLSTATE=40001)
  5. 会计转行SAP FICO实施顾问,百万年薪等你来挑战!
  6. 订单生产计划表范本_生产计划管理与物料控制的实施步骤与要领
  7. 无需复杂插件即可从Eclipse启动和调试Tomcat
  8. servlet核心API的UML图
  9. C# 数据的加密解密
  10. python自动化运维书籍推荐_《Python 自动化运维:技术与最佳实践》
  11. hdu-5867 Water problem(水题)
  12. jQuery:点击某元素后根据兄弟节点是否显示,控制兄弟节点的显示与否
  13. ConcurrentModificationException---异常剖析
  14. 玩转 ESP32 + Arduino (十九) SIM800L上传数据到OneNet(新版Mqtts)
  15. kubernetes实践分享
  16. Delphi开发Windows之WMI
  17. MySQL 权限操作
  18. 苹果CMSV10仿芒果TV影视PC+WAP模板
  19. STM32F407——矩阵键盘
  20. Python3输出格式化时间yyyy-mm-dd HH:MM:SS

热门文章

  1. Java里optionsMenu.add_Android中OptionMenu的使用总结
  2. c++后台管理系统_【获奖案例】第三届全国医院物联网大会“中国医院物联网应用十大优秀案例”安徽医科大学第一附属医院手术室行为管理系统...
  3. “本机号码一键登录”是如何实现?
  4. Apple Music 会员免费领啦!
  5. 你真的了解 OpenJDK 吗?
  6. JedisPool资源池优化
  7. pytorch默认初始化_小白学PyTorch | 9 tensor数据结构与存储结构
  8. mysql中有哪些数值型函数_mysql数值型函数汇总
  9. 大于小于优化_以MySQL为例,详解数据库索引原理及深度优化
  10. Focal Loss升级:让Focal Loss动态化,类别极端不平衡也可以轻松解决