Java往oracle存clob类型的值时,字符长度过长怎么办?

createh53个月前 (02-01)技术教程17

业务场景

将照片转为数字长串后,由于字符过长,java往数据库中直接存为clob字段时,oracle会报ORA-01704问题:字符串文字过长。

这是因为一般对含有CLOB字段的数据操作。

如果CLOB字段的内容非常大的时候,会导致SQL语句过长。

隐式转换:oracle默认把字符串转换成varchar2类型,varchar2类型最大字符串的长度为4000,当字段长度比4000大时,所以会报ora-01704错误。

简言之,就是两个单引号之间的字符长度不能超过4000。

解决办法总结

试过几种办法,发现只有最后一种是有效的,现将错误与正确的方法都进行了总结,错误的进行避免,正确的可以借鉴。

1.将字符串按照固定长度截取,insert语句:to_clob('字符1' || '字符2' || '字符3' || '字符4' .......),此方法无效,隐式转换成了varchar2,字符长度超过4000;

2.将超长字段按照一定的长度进行截取,用to_clob()函数拼接insert语句,将截取的字符用连接符 ‘||’ 连接起来存入clob字段中,insert语句:to_clob('字符1') || to_clob('字符2') || to_clob('字符3') || to_clob('字符4') ....... 此方法有效。

/**
 * 将超长的内容转为clob可以保存的句式
 * 字符串每隔2000长度插入指定字符串 ' ) || TO_CLOB( '
 * @param original         处理超长字符串
 * @param insertString     插入字符串 ') || TO_CLOB('
 * @param interval         间隔的字符长度 2000
 * @return
 */
public static String stringInsertByInterval(String original, String insertString, int interval) {
   if (original == null) return "";
   Integer len = original.length();
   if (interval >= len) return original;

   String rtnString = original;
   if (original.length() > interval) {
      List strList = new ArrayList();
      Pattern p = Pattern.compile("(.{" + interval + "}|.*)");
      Matcher m = p.matcher(original);
      while (m.find()) {
         strList.add(m.group());
      }
      strList = strList.subList(0, strList.size() - 1);
      rtnString = StringUtils.join(strList, insertString);
   }
   rtnString = “'TO_CLOB('” + rtnString + "')";
   return rtnString;
}


作者:赵小可
链接:
https://juejin.cn/post/7019677362035884063

来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关文章

截取字符串——Substring用法(substring截取字符串数据库)

string类提供了一个Substring方法,可以截取字符串中指定位置和指定长度的字符。详细讲解:namespace ConsoleApplication2 { class Program...

Java实现MD5加盐加密算法(java中md5加密)

MD5加密MD5是常用的加密算法,在用户注册时通过算法加密的密码存入数据库,保护用户密码,数据库管理员不能直接看见密码,即使用户数据库被盗,没有存储明文的密码对用户来说也多了一层安全保障。用户登录时,...

教大家简单的 Shell 脚本入门操作

Shell脚本 运作方式与解释型语言相当,如果有语言基础,学起 Shell 脚本就非常容易,但是 Shell 与常见的语言不同,一些常见的函数在 Shell 中需要组合一些命令得以实现工具推荐Shel...

Easysearch Java SDK 2.0.x 使用指南(三)

在 Easysearch Java SDK 2.0.x 使用指南(一) 中,我们介绍了 Easysearch Java SDK 2.0.2 的基本使用和批量操作功能。在 Easysearch Java...

我接手前同事写的烂Java代码,不小心搞出了一个内存泄露事故

目录String 字符串在内存里是如何存储的?String.intern() 方法String 字符串是如何引发内存泄漏呢?总结今天给大家聊聊咱们平时写代码的时候,最常见的 String 字符串代码,...

手把手教你从零开始用Java写爬虫(java写网络爬虫)

本文将手把手地教大家从零开始用Java写一个简单地爬虫!目标 爬取全景网图片,并下载到本地收获 通过本文,你将复习到:IDEA创建工程IDEA导入jar包爬虫的基本原理Jsoup的基本使用File的...