解决MyBatis查询oracle的NCLOB类型都是内存地址字符串

在项目的配置类文件夹中放入如下通用类OracleResultSetInterceptor

java 复制代码
import org.apache.ibatis.executor.resultset.ResultSetHandler;
import org.apache.ibatis.plugin.*;

import java.io.IOException;
import java.io.Reader;
import java.io.StringWriter;
import java.sql.NClob;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;

@Intercepts({
    @Signature(type = ResultSetHandler.class, method = "handleResultSets", args = { Statement.class })
})
public class OracleResultSetInterceptor implements Interceptor {

    /**
     * 用于设置拦截器的属性
     * 在这里可以根据需要设置拦截器的具体配置,例如通过配置文件传递一些参数或者初始化一些资源
     * @param properties
     */
    @Override
    public void setProperties(Properties properties) {
    }

    /**
     * 包装目标对象,返回一个代理对象
     * @param target 目标对象
     * @return 代理对象
     */
    @Override
    public Object plugin(Object target) {
        return Plugin.wrap(target, this);
    }

    /**
     * 代理对象处理逻辑
     * @param invocation 包含参数,结果集
     */
    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        Object result = invocation.proceed(); // 执行原始方法获取结果
        if (result instanceof Map) {
            Map<String, Object> resultMap = (Map<String, Object>) result;
            processMap(resultMap);
        }else if(result instanceof List){
            List<Object> list=(List<Object>)result;
            for (Object line:list){
                if(line instanceof Map){
                    processMap((Map<String,Object>)line);
                }
            }
        }
        return result;
    }

    /**
     * 处理map
     * @param line
     * @throws SQLException
     * @throws IOException
     */
    private void processMap(Map<String,Object> line) throws SQLException, IOException {
        for (String key:line.keySet()){
            Object value = line.get(key);
            if (value instanceof NClob) {
                NClob nclob = (NClob) value;
                String nclobString = convertNClobToString(nclob);
                line.put(key, nclobString);
            }
        }
    }

    private String convertNClobToString(NClob nclob) throws SQLException, IOException {
        // 将 NCLOB 数据读取为字符串
        Reader reader = nclob.getCharacterStream();
        StringWriter writer = new StringWriter();
        char[] buffer = new char[1024];
        int bytesRead;
        while ((bytesRead = reader.read(buffer)) != -1) {
            writer.write(buffer, 0, bytesRead);
        }
        return writer.toString();
    }


}

配置文件启用mybatis自定义插件

java 复制代码
mybatis:
  configuration:
    plugins:
      - interceptor: your.package.CustomResultSetInterceptor
java 复制代码
<configuration>
    <plugins>
        <plugin interceptor="your.package.CustomResultSetInterceptor"/>
    </plugins>
</configuration>
相关推荐
阿杰 AJie4 分钟前
MySQL 聚合函数
android·数据库·mysql
菜鸟小九8 分钟前
redis高级(存储能力问题)
数据库·redis·缓存
+VX:Fegn089512 分钟前
计算机毕业设计|基于springboot + vue酒店预订系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
hunter145039 分钟前
2026.1.20 sql server简单操作
数据库·oracle
达梦产品与服务1 小时前
SQLark 实战 | 如何快速导入数据至达梦、Oracle、MySQL、PG 数据库
mysql·oracle·达梦数据库·数据导入·pg数据库
独自破碎E1 小时前
MyBatis Flex和MyBatis Plus的区别
java·开发语言·mybatis
liux35281 小时前
MySQL集群架构:MySQL InnoDB Cluster (MIC)详解(十一)
数据库·mysql·架构
小北方城市网1 小时前
MySQL 索引优化实战:从慢查询到高性能
数据库·spring boot·后端·mysql·rabbitmq·mybatis·java-rabbitmq
Chan161 小时前
《Java并发编程的艺术》| 并发关键字与 JMM 核心规则
java·开发语言·数据库·spring boot·java-ee·intellij-idea·juc
l1t1 小时前
DeepSeek对AliSQL 集成 DuckDB 的总结
数据库·sql·mysql·duckdb