入參:字段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; }
配置是結束, 直接使用就行