一. 測試環境
數據庫 : mysql
字段類型:varchar 值為數組類型
實體類對象屬性對應類型: String [] 數組類型
查詢方式: 兩表聯查
二. 問題描述
mybatis查詢字段類型為數組的字段時,值為空,數據庫查詢可以查詢出來
三 . 已排除的問題
1. 實體類對象屬性和sql列名一致
四. 解決方法
1. result 加上 typeHandler 做類型的裝換
<result property="specifications" column="specifications" typeHandler="com.test.JsonStringArrayTypeHandler"></result>
2.JsonStringArrayTypeHandler 代碼如下
package com.test; import com.fasterxml.jackson.databind.ObjectMapper; import org.apache.ibatis.type.BaseTypeHandler; import org.apache.ibatis.type.JdbcType; import java.sql.CallableStatement; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; /* <columnOverride column="urls" javaType="java.lang.String[]" typeHandler="JsonStringArrayTypeHandler"/> */ 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; } } }