MyBatis Plus数组list存入数据库之TypeHanlder类转换器

 
入参:字段String[] 直接存入数据库
  TypeHandler概念
    MyBatis 中的 TypeHandler 类型处理器用于 JavaType 与 JdbcType 之间的转换
1.数据库字段类型更改为json, mysql版本需要5.7.1以上

 

 


 

 

自定义转换器
import com.fasterxml.jackson.databind.ObjectMapper;
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 java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Set;

/*
   <columnOverride column="urls" javaType="java.lang.String[]" typeHandler="JsonStringArrayTypeHandler"/>
 */
@MappedJdbcTypes({JdbcType.VARCHAR})
public class JsonStringArrayTypeHandler extends BaseTypeHandler<String[]> {
    private static final ObjectMapper mapper = new ObjectMapper();

    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, String[] parameter, JdbcType jdbcType) throws SQLException {
        ps.setString(i,toJson(parameter));
    }

    @Override
    public String[] getNullableResult(ResultSet rs, String columnName) throws SQLException {
        return this.toObject(rs.getString(columnName));
    }

    @Override
    public String[] getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        return this.toObject(rs.getString(columnIndex));
    }

    @Override
    public String[] getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        return this.toObject(cs.getString(columnIndex));
    }

    private String toJson(String[] params) {
        try {
            return mapper.writeValueAsString(params);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return "[]";
    }

    private String[] toObject(String content) {
        if (content != null && !content.isEmpty()) {
            try {
                return (String[]) mapper.readValue(content, String[].class);
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        } else {
            return null;
        }
    }
}

 

 
实体类加上以下2个注释.
  遇到autoResultMap 无法识别, 去官网看了下最新版本Ok了 我只能告诉你<version>3.4.1</version>支持
    @TableName(autoResultMap = true,value="tb_post")
    @TableField(typeHandler = JsonStringArrayTypeHandler.class)
  官方对这个字段的解释,新版本的也不需要去xml配置
 
@Data
@TableName(autoResultMap = true,value="tb_post")
public class Post implements Serializable {
    private static final long serialVersionUID = 321216665472999991L;
    /**
     * 帖子id
     */
    @TableId
    private Long id;
  
    /**
     * 图片路径 一对多
     */
    @TableField(typeHandler = JsonStringArrayTypeHandler.class)
    private String[] imgUrl;

   
}

 

  

配置是结束, 直接使用就行

 

posted @ 2020-11-27 18:32  九涯  阅读(6899)  评论(0编辑  收藏  举报