我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何使用mybatis的typeHandler对clob进行流读写

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何使用mybatis的typeHandler对clob进行流读写

这篇文章主要介绍“如何使用mybatis的typeHandler对clob进行流读写”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何使用mybatis的typeHandler对clob进行流读写”文章能帮助大家解决问题。

    typeHandler对clob进行流读写

    分为三步:

    第一步:编写typehandler文件

    package com.dcits.edps.common.utils; import java.io.ByteArrayOutputStream;import java.io.IOException;import java.io.OutputStream;import java.io.OutputStreamWriter;import java.io.Reader;import java.io.StringReader;import java.io.Writer;import java.sql.CallableStatement;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException; import org.apache.ibatis.type.BaseTypeHandler;import org.apache.ibatis.type.JdbcType;import org.apache.ibatis.type.MappedJdbcTypes;import org.apache.ibatis.type.MappedTypes;import org.springframework.util.FileCopyUtils;  @MappedTypes({String.class}) @MappedJdbcTypes({JdbcType.CLOB}) public class OscarClobTypeHandler extends BaseTypeHandler<String> {@Overridepublic void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType)throws SQLException {final StringReader sr = new StringReader(parameter);final int length = parameter.getBytes().length;ps.setCharacterStream(i, sr, length);sr.close();} @Overridepublic String getNullableResult(ResultSet rs, String columnName) throws SQLException {final OutputStream outPutStream = new ByteArrayOutputStream();final Writer writer = new OutputStreamWriter(outPutStream);try {Reader reader = rs.getCharacterStream(columnName);if(null == reader){return null;}else {FileCopyUtils.copy(reader, writer);}} catch (IOException e) {e.printStackTrace();}return outPutStream.toString();} @Overridepublic String getNullableResult(ResultSet rs, int columnIndex) throws SQLException {final OutputStream outPutStream = new ByteArrayOutputStream();final Writer writer = new OutputStreamWriter(outPutStream);try {Reader reader = rs.getCharacterStream(columnIndex);if(null == reader){return null;}else {FileCopyUtils.copy(reader, writer);} }catch (IOException e) {e.printStackTrace();}return outPutStream.toString();} @Overridepublic String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {final OutputStream outPutStream = new ByteArrayOutputStream();final Writer writer = new OutputStreamWriter(outPutStream);try {Reader reader = cs.getCharacterStream(columnIndex);if(null == reader){return null;}else {FileCopyUtils.copy(reader, writer);}} catch (IOException e) {e.printStackTrace();}return outPutStream.toString();}  }

    第二步:在mybatis的配置文件中添加<typeHandlers>节点

    需要注意的是,mybatisd的配置文件中的<configuration>节点中的子节点需要有顺序

    顺序为:properties&mdash;>settings&mdash;>typeAliases&mdash;>typeHandlers&mdash;>objectFactory&mdash;>objectWrapperFactory&mdash;>plugins&mdash;>environments&mdash;>databaseIdProvider&mdash;>mappers。

    <typeHandlers>    <typeHandler handler="com.dcits.edps.common.utils.OscarClobTypeHandler"/> </typeHandlers>

    第三步

    ①在resultMap中需要添加jdbcType,这是在读取时使用了流,如下所示

     <resultMap type="com.dcits.edps.swgl.common.bean.SwMain" id="swmain">      <result property="fsfh" column="fsfh" jdbcType="CLOB"/>  </resultMap>

    ② 在写入数据的时候使用:

    fsfh=#{fsfh,jdbcType=CLOB}

    mybatis处理clob字段

    由于数据库中 ggnr 字段是clob 类型(可以存储流对象),所以后台对前台传递的长文本进行处理。

    经过一番查找,找到mybatis处理clob字段的方法,对clob 进行了尝试处理,发现存的数据长度超过一两百,数据库该字段就为空,存的短可以。

    经过查阅跟公司同事沟通,总结两种方案:(1).直接获取数据库连接,操作预编译对象(老方法,高并发数据库容易卡死,不符)。(2).sql使用 begin end 方法(经测试可以存储字节4000以内的数据,要求不符)

    好吧再次查阅jdbc官方文档,上边提到ojdbc 存在数据限制情况,建议高版本,然后就换了ojdbc6 问题解决。

    换了之后,ok。如果有懒加载,添加上这个 cglib-nodep-3.2.4.jar

    附上Mapper处理:

    修改Mapper.xml

      <result column="GGNR" property="ggnr"  javaType="java.lang.String" jdbcType="CLOB" typeHandler="org.apache.ibatis.type.ClobTypeHandler"/>

    sql

        insert into CQGG(ggnr) values(#{ggnr,jdbcType=CLOB})

    关于“如何使用mybatis的typeHandler对clob进行流读写”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    如何使用mybatis的typeHandler对clob进行流读写

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    如何使用mybatis的typeHandler对clob进行流读写

    这篇文章主要介绍“如何使用mybatis的typeHandler对clob进行流读写”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何使用mybatis的typeHandler对clob进行流读写”
    2023-06-26

    C#如何使用NPOI对word进行读写

    这篇文章主要介绍了C#如何使用NPOI对word进行读写的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C#如何使用NPOI对word进行读写文章都会有所收获,下面我们一起来看看吧。一、简介操作Word的类库:N
    2023-07-02

    Linux下如何使用Octave对文件进行读写操作

    小编给大家分享一下Linux下如何使用Octave对文件进行读写操作,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Octave 是一个 Linux 上类似于 Ma
    2023-06-27

    在spring中使用mybatis实现对mysql数据库进行读写分离

    这期内容当中小编将会给大家带来有关在spring中使用mybatis实现对mysql数据库进行读写分离,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言 在网站的用户达到一定规模后,数据库因为
    2023-05-31

    使用Spring Boot如何对Mybatis进行整合

    今天就跟大家聊聊有关使用Spring Boot如何对Mybatis进行整合,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。依赖配置结合前面的内容,这里我们要嵌入数据库的操作,这里以操作
    2023-05-31

    linux中如何使用Octave对音频文件进行读写操作

    这篇文章主要介绍了linux中如何使用Octave对音频文件进行读写操作,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Octave 是一个 Linux 上类似于 Matlab
    2023-06-16

    C#中如何使用文件IO和流操作进行数据读写

    C#中如何使用文件IO和流操作进行数据读写,需要具体代码示例在C#编程中,文件IO和流操作是常用的技术,用于读取和写入文件的数据。无论是处理文本文件、二进制文件,还是读取网络流数据,我们都可以通过文件IO和流操作来实现。文件IO和流操作提供
    2023-10-22

    使用Spring boot如何实现对Mybatis进行集成

    使用Spring boot如何实现对Mybatis进行集成?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。本章目标整合 Mybatis ,并集成 Druid 数据
    2023-05-31

    C++ qt如何使用jsoncpp json进行读写操作

    这篇文章将为大家详细讲解有关C++ qt如何使用jsoncpp json进行读写操作,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。JsonCpp的使用项目需要c++下使用json,我选择了J
    2023-06-21

    如何进行Python数据编组对文字串的读写

    如何进行Python数据编组对文字串的读写,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。使用前一节中介绍的模块,可以实现在文件中对字符串的读写。然而,有的时候,
    2023-06-17

    如何使用 libp2p 在 golang 中处理对等点的缓冲读写流?

    你在学习Golang相关的知识吗?本文《如何使用 libp2p 在 golang 中处理对等点的缓冲读写流?》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!问题内
    如何使用 libp2p 在 golang 中处理对等点的缓冲读写流?
    2024-04-04

    聊聊如何利用纯C语言对EXCEL进行读写操作

    如何利用纯C语言对EXCEL进行读写操作?下面本篇文章给大家介绍一下通过纯C语言进行EXCEL读写操作的方法,希望对大家有所帮助!在之前需要使用C语言读取Excel文件内容的功能,查阅了很多资料,大部分是通过ODBC或者过OLE/COM对Excel表格的读取操作,这变要求在工程中添加类,如CApplicaton及其头文件等,这包括Excel接口、导入类、头文件等。操作十分复杂,当然我也对这种方法进行
    2022-07-07

    C#中如何使用文件IO和流操作进行数据读写及解决方法

    C#中如何使用文件IO和流操作进行数据读写及解决方法在开发过程中,我们常常需要进行文件的读写操作。C#提供了丰富的文件IO和流操作,使得数据的读写变得更加灵活和高效。本文将探讨C#中如何使用文件IO和流操作进行数据读写,并提供具体的代码示例
    2023-10-22

    如何使用PHP进行文件读写操作?(PHP读取和写入文件的方法有哪些?)

    PHP提供多种文件读写方法,包括:fopen()和fwrite()、file_put_contents()、file()和file_put_contents()、fopen()和fgets()、fseek()和fread()、copy()、unlink()、PHPstreams、FilesystemIterator和FileInfo。选择方法取决于需求和限制。fopen()和fwrite()用于低级操作,file_put_contents()和file()更简单,PHPstreams和Filesystem
    如何使用PHP进行文件读写操作?(PHP读取和写入文件的方法有哪些?)
    2024-04-02

    如何在Spring中使用MyBatis实现数据的读写分离

    如何在Spring中使用MyBatis实现数据的读写分离?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。其实现原理如下:通过Spring AOP对dao层接口进行
    2023-05-31

    PHP开发中如何使用Memcache进行高效的数据读写操作?

    在 PHP 开发中,使用 Memcache 缓存系统可以大大提高数据读写的效率。Memcache 是一种基于内存的缓存系统,它可以将数据缓存在内存中,避免频繁的读写数据库。本文将介绍如何在 PHP 中使用 Memcache 进行高效的数据读
    PHP开发中如何使用Memcache进行高效的数据读写操作?
    2023-11-07

    使用Spring MVC与Mybatis如何对Mysql数据库进行分页查询

    使用Spring MVC与Mybatis如何对Mysql数据库进行分页查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。第一步,搭建这个小案例,引入spring和mybtis的
    2023-05-31

    使用Mybatis如何实现对数据库进行增删改查操作

    本篇文章为大家展示了使用Mybatis如何实现对数据库进行增删改查操作,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。什么是 MyBatis?MyBatis 是支持普通 SQL 查询,存储过程和高级映
    2023-05-31

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录