前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mybatis 自定义转换器 ListTypeHandler

mybatis 自定义转换器 ListTypeHandler

作者头像
用户9131103
发布2023-07-17 19:49:36
5140
发布2023-07-17 19:49:36
举报
文章被收录于专栏:工作经验工作经验

mybatis 自定义转换器 ListTypeHandler 实现存库 list->string

代码语言:javascript
复制
读库 string->list
代码语言:javascript
复制
package com.jeesite.modules.handler;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.TypeReference;
import com.jeesite.common.lang.ObjectUtils;
import com.jeesite.common.lang.StringUtils;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedJdbcTypes;
import org.apache.ibatis.type.MappedTypes;
<!--more-->
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
/**
 * @author liuxin
 * @version 1.0
 * @date 2022/8/23 12:25
 */
@MappedJdbcTypes(JdbcType.VARCHAR)
@MappedTypes({List.class})
public abstract class ListTypeHandler<T> extends BaseTypeHandler<List<T>> {

  @Override
  public void setNonNullParameter(PreparedStatement ps, int i, List<T> parameter, JdbcType jdbcType)
      throws SQLException {
    String content = ObjectUtils.isEmpty(parameter) ? null : JSON.toJSONString(parameter);
    ps.setString(i, content);
  }

  @Override
  public List<T> getNullableResult(ResultSet rs, String columnName) throws SQLException {
    return this.getListByJsonArrayString(rs.getString(columnName));
  }

  @Override
  public List<T> getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
    return this.getListByJsonArrayString(rs.getString(columnIndex));
  }

  @Override
  public List<T> getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
    return this.getListByJsonArrayString(cs.getString(columnIndex));
  }

  private List<T> getListByJsonArrayString(String content) {
    return StringUtils.isBlank(content)
        ? new ArrayList<>()
        : JSON.parseObject(content, this.specificType());
  }

  /**
   * 具体类型,由子类提供
   *
   * @return 具体类型
   */
  protected abstract TypeReference<List<T>> specificType();
}
代码语言:javascript
复制
 Java 泛型 如果在 ListTypeHandler 类中直接提供 TypeReference<List<T>> 这种类型,那就等效于TypeReference<List<Object>> 这种类型,后续 fastjson 在转换时无法确定具体的 Java 类型,转换后的类型最终就会是 List<JSONObject> ;同理,如果使用 Jackson 作为 JSON 转换工具,不确定具体类型时,最总会被转换为LinkedHashMap 类型,都需要再使用 TypeReference 来转换一次。

自定义TypeHandler的使用笔记 可通过自定义的TypeHandler实现某个属性在插入数据库以及查询时的自动转换。
代码语言:javascript
复制
package com.jeesite.modules.handler;

/**
 * @author liuxin
 * @version 1.0
 * @date 2022/8/23 12:33
 */

import com.alibaba.fastjson.TypeReference;
import com.pdd.pop.sdk.http.api.pop.response.PddGoodsListGetResponse;

import java.util.List;

public class SkuListItemSpecDetailsTypeHandler
        extends ListTypeHandler<PddGoodsListGetResponse.GoodsListGetResponseGoodsListItemSkuListItemSpecDetailsItem> {
    @Override
    protected TypeReference<List<PddGoodsListGetResponse.GoodsListGetResponseGoodsListItemSkuListItemSpecDetailsItem>> specificType() {
        return new TypeReference<List<PddGoodsListGetResponse.GoodsListGetResponseGoodsListItemSkuListItemSpecDetailsItem>>() {
        };
    }
}

实体类上直接用注解:

代码语言:javascript
复制
 typeHandler = ListTypeHandler.class,
 javaType = PddGoodsListGetResponse.GoodsListGetResponseGoodsListItemSkuListItemSpecDetailsItem.class

mapper.xml

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jeesite.modules.pdd.dao.PddGoodsSkuListDao">

    <resultMap type="com.jeesite.modules.pdd.entity.PddGoodsSkuList" id="PddGoodsSkuListMap">
        <!--column需要和数据库字段名对应,当实体上面设置了属性名则和属性名对应-->
        <result column="specDetails" property="specDetails"
                javaType="java.util.List" typeHandler="com.jeesite.modules.handler.SkuListItemSpecDetailsObjectTypeHandler"/>
    </resultMap>
    <select id="findList" resultMap="PddGoodsSkuListMap">
        SELECT ${sqlMap.column.toSql()}
        FROM ${sqlMap.table.toSql()}
        <where>
            ${sqlMap.where.toSql()}
        </where>
        ORDER BY ${sqlMap.order.toSql()}
    </select>
</mapper>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年12月07日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档