《Java EE核心框架实战》—— 2.7 插入超大的字符串文本内容

简介: MyBatis框架也支持Oracle的CLOB,不需要特别的环境配置即可完成对CLOB字段的操作。

本节书摘来异步社区《Java EE核心框架实战》一书中的第2章,第2.7节,作者: 高洪岩,更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.7 插入超大的字符串文本内容

MyBatis框架也支持Oracle的CLOB,不需要特别的环境配置即可完成对CLOB字段的操作。

创建名为bigCLOB的Web项目,映射文件userinfoMapping.xml的代码如下。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "mybatis-3-mapper.dtd">
<mapper namespace="mybatis.testcurd">
 <insert id="insertBigString" parameterType="map">
  <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.Long">
   select idauto.nextval from dual
  </selectKey>
  insert into bigclob(id,bigstring) values(#{id},#{bigstring})
 </insert>
 <select id="selectById" resultType="map">
  select * from bigclob where
  id=10000
 </select>
</mapper>```
创建名为test的Servlet,核心代码如下。

public class test extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
try {
SqlSession sqlSessionRef = GetSqlSession.getSqlSession();
Map map = sqlSessionRef.selectOne("selectById");
Clob clobRef = (Clob) map.get("BIGSTRING");
Reader reader = clobRef.getCharacterStream();
BufferedReader brRef = new BufferedReader(reader);
char[] charArray = new char[2048];
int readLength = brRef.read(charArray);
while (readLength != -1) {

String bigString = new String(charArray, 0, readLength);
System.out.println(bigString);
readLength = brRef.read(charArray);

}
Map insertMap = new HashMap();
insertMap.put("id", 20000);
insertMap.put("bigstring", clobRef);
sqlSessionRef.insert("insertBigString", insertMap);
sqlSessionRef.commit();
sqlSessionRef.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}`
默认情况下Oracle数据表中有一条包含50万行的CLOB字段,如图2-11所示。

29874e5110a78eba2773799c485e26d22e2d5267

程序运行后,在控制台输出了最后一行信息,如图2-12所示。

数据表中还插入了另外一条50万行的记录,如图2-13所示。

93c2fcea2a931473752f89698043594714d1cd30

本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。

相关文章
|
15天前
|
Java
Java 字符串分割split空字符串丢失解决方案
Java 字符串分割split空字符串丢失解决方案
|
18天前
|
设计模式 安全 Java
Java并发编程实战:使用synchronized关键字实现线程安全
【4月更文挑战第6天】Java中的`synchronized`关键字用于处理多线程并发,确保共享资源的线程安全。它可以修饰方法或代码块,实现互斥访问。当用于方法时,锁定对象实例或类对象;用于代码块时,锁定指定对象。过度使用可能导致性能问题,应注意避免锁持有时间过长、死锁,并考虑使用`java.util.concurrent`包中的高级工具。正确理解和使用`synchronized`是编写线程安全程序的关键。
|
1天前
|
安全 Java 调度
Java线程:深入理解与实战应用
Java线程:深入理解与实战应用
9 0
|
5天前
|
Java Maven 开发工具
《Java 简易速速上手小册》第5章:Java 开发工具和框架(2024 最新版)
《Java 简易速速上手小册》第5章:Java 开发工具和框架(2024 最新版)
26 1
|
5天前
|
存储 Java 数据库连接
java DDD 领域驱动设计思想的概念与实战
【4月更文挑战第19天】在Java开发中,领域驱动设计(Domain-Driven Design, DDD) 是一种软件设计方法论,强调以领域模型为中心的软件开发。这种方法通过丰富的领域模型来捕捉业务领域的复杂性,并通过软件满足核心业务需求。领域驱动设计不仅是一种技术策略,而且还是一种与业务专家紧密合作的思维方式
22 2
|
9天前
|
Java 大数据 云计算
Spring框架:Java后台开发的核心
【4月更文挑战第15天】Spring框架在Java后台开发中占据核心位置,因其控制反转(IoC)、面向切面编程(AOP)、事务管理等特性提升效率和质量。Spring提供数据访问集成、RESTful Web服务和WebSocket支持。优势包括高效开发、灵活扩展、强大生态圈和广泛应用。应用于企业级应用、微服务架构及云计算大数据场景。掌握Spring对Java开发者至关重要。
|
12天前
|
存储 Java 编译器
Java集合丛林:深入了解集合框架的秘密
Java集合丛林:深入了解集合框架的秘密
15 0
Java集合丛林:深入了解集合框架的秘密
|
15天前
|
Java API 开发者
Java 8新特性之函数式编程实战
【4月更文挑战第9天】本文将深入探讨Java 8的新特性之一——函数式编程,通过实例演示如何运用Lambda表达式、Stream API等技术,提高代码的简洁性和执行效率。
|
15天前
|
存储 Java 数据库连接
java使用mp持久化框架,写入5000个字符,但是VARCHAR(255) 会报错
使用Java的MyBatis Plus框架时,如果尝试将超过VARCHAR(255)限制的字符串(如5000个字符)存入数据库,会抛出异常。解决方法是将列类型改为TEXT。可通过在实体类属性上添加`@TableField(typeHandler = JdbcType.CLOB)`注解,如`private String content;`,将属性映射到CLOB类型列,以存储更长字符串。
9 0
|
16天前
|
存储 Java
java反射——设计框架的灵魂
java反射——设计框架的灵魂