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;

   
}

 

  

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM