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

Mybatis -如何处理clob类型数据

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

Mybatis -如何处理clob类型数据

Mybatis 处理clob类型数据

当执行sql语句,返回的是map类型时, 比如


public List<Map<String, Object>> query(@Param("sql") String sql)

得到的数据是List<Map>类型数据,此时,如果有返回的有clob字段时,数据是这样的oracle.sql.CLOB@63636de0 ,显然,这不是我想要的,我需要的是字符串数据

那么怎么来处理clob字段呢,很简单

就是定义类型处理器,来专门处理Clob字段,将Clob数据转换为字符串数据返回


@MappedJdbcTypes(JdbcType.CLOB)
public class ClobTypeHandle extends BaseTypeHandler<Object> {
    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, Object parameter, JdbcType jdbcType)
            throws SQLException {
        ps.setObject(i, parameter);
    }
    @Override
    public Object getNullableResult(ResultSet rs, String columnName) throws SQLException {
        return rs.getString(columnName);
    }
    @Override
    public Object getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        return rs.getString(columnIndex);
    }
    @Override
    public Object getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        return cs.getString(columnIndex);
    }
}

Mybatis 大字段clob处理

1. 实体类View


package com.ttt.sysManager.po;
public class View {
 private String VIEW_NAME;
 private String TEXT_LENGTH;
 private String TEXT;<span style="white-space:pre"> </span>// clob大字段
 private String EDITIONING_VIEW;
 private String READ_ONLY;
        // ...(get、set方法)
}

2. Dao


List<View> getViewByPage(Map<String, Object> map);

3. XML


<resultMap id="viewResultMap" type="com.ttt.sysManager.po.View">     
        <result property="VIEW_NAME" column="VIEW_NAME"/>
        <result property="TEXT_LENGTH" column="TEXT_LENGTH"/>  
        <result property="TEXT" column="TEXT" javaType="String" jdbcType="VARBINARY"/>  
        <result property="EDITIONING_VIEW" column="EDITIONING_VIEW" />  
        <result property="READ_ONLY" column="READ_ONLY" />  
</resultMap>  
 
<select id="getViewByPage" parameterType="map" resultMap="viewResultMap" >
 SELECT VIEW_NAME,TEXT_LENGTH,TEXT,EDITIONING_VIEW,READ_ONLY FROM (
  SELECT A.*,  ROWNUM RN
    FROM (SELECT * FROM user_views) A
    WHERE ROWNUM <![CDATA[<=]]> #{endRow}
  ) WHERE RN <![CDATA[>]]> #{startRow}
</select>

4. 写入

写入大字段与普通写入无区别,但是数据库字段类型需为clob,如为blob会报错,暂不解决。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

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

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

Mybatis -如何处理clob类型数据

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

下载Word文档

猜你喜欢

java对clob类型数据如何处理

在Java中处理CLOB类型数据有多种方法,可以使用JDBC API、Hibernate、MyBatis等工具来操作CLOB类型数据。1. 使用JDBC API:- 获取CLOB数据:通过ResultSet对象的getClob方法获取CLO
2023-10-18

java如何对clob类型数据进行处理

在Java中,可以使用`java.sql.Clob`接口来对CLOB类型数据进行处理。以下是一些常见的处理方法:1. 读取CLOB数据:可以使用`Clob`接口的`getCharacterStream()`方法获取CLOB数据的字符流,然后
java如何对clob类型数据进行处理
2023-10-30

mysql中clob类型数据怎么处理

在MySQL中,CLOB(Character Large Object)类型数据通常指代文本类型数据,例如长文本、大段文本或者大型文件等。在MySQL中,CLOB类型数据可以使用TEXT或LONGTEXT数据类型来存储。处理CLOB类型数
mysql中clob类型数据怎么处理
2024-04-09

MariaDB中如何处理JSON数据类型

如何处理MariaDB中的JSON数据类型MariaDB支持JSON数据类型,可用于存储和操作复杂数据结构。本文介绍了如何创建、访问、修改和查询JSON数据,以及最佳实践和内置JSON函数和运算符的使用。通过使用JSON数据类型,可以存储复杂数据、简化查询并增强应用程序灵活性。
MariaDB中如何处理JSON数据类型
2024-04-12

MariaDB中如何处理JSON数据类型

在MariaDB中,JSON数据类型可以用来存储和查询JSON格式的数据。要处理JSON数据类型,可以使用各种函数和操作符来操作JSON数据。以下是一些常用的JSON处理函数和操作符:1、JSON_EXTRACT: 用于从JSON数据中提
MariaDB中如何处理JSON数据类型
2024-04-09

PHP中如何将CLOB类型的数据转换为字符串

这篇文章主要介绍“PHP中如何将CLOB类型的数据转换为字符串”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“PHP中如何将CLOB类型的数据转换为字符串”文章能帮助大家解决问题。方法一:使用Orac
2023-07-06

MyBatis中怎么使用TypeHandler处理特殊数据类型

在 MyBatis 中使用 TypeHandler 处理特殊数据类型的步骤如下:创建一个自定义的 TypeHandler 类,继承自 org.apache.ibatis.type.BaseTypeHandler 接口,并实现其方法,例如:p
MyBatis中怎么使用TypeHandler处理特殊数据类型
2024-04-08

Golang泛型如何在函数中处理不同类型的数据?

go 泛型通过类型参数允许函数处理不同类型的数据。通过使用可比较类型参数 t,max 函数可以返回两个值中较大的那个,适用于任何可比较类型。Go 泛型:在函数中处理不同类型数据Go 泛型允许我们创建适用于多种类型的通用代码。以下是如何在
Golang泛型如何在函数中处理不同类型的数据?
2024-04-17

编程热搜

  • 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动态编译

目录