1.装配类
import cn.hutool.core.util.ObjectUtil;
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 org.springframework.util.StringUtils;
import java.math.BigDecimal;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.LinkedList;
import java.util.List;
@MappedJdbcTypes(JdbcType.VARCHAR)
@MappedTypes({List.class})
public class BigDecimalListTypeHandler extends BaseTypeHandler<List<BigDecimal>> {
private static final String DELIM = ",";
@Override
public void setNonNullParameter(PreparedStatement preparedStatement, int i, List<BigDecimal> strings, JdbcType jdbcType) throws SQLException {
String value = StringUtils.collectionToDelimitedString(strings, DELIM);
preparedStatement.setString(i, value);
}
@Override
public List<BigDecimal> getNullableResult(ResultSet resultSet, String s) throws SQLException {
String value = resultSet.getString(s);
return this.getBigDecimal(value);
}
@Override
public List<BigDecimal> getNullableResult(ResultSet resultSet, int i) throws SQLException {
String value = resultSet.getString(i);
return this.getBigDecimal(value);
}
@Override
public List<BigDecimal> getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
String value = callableStatement.getString(i);
return this.getBigDecimal(value);
}
private List<BigDecimal> getBigDecimal(String value) {
List<BigDecimal> bigDecimals = new LinkedList<>();
if (ObjectUtil.isNotEmpty(value)) {
String[] strings = StringUtils.tokenizeToStringArray(value, DELIM);
if (strings.length > 0) {
for (String string : strings) {
bigDecimals.add(new BigDecimal(string));
}
}
}
return bigDecimals;
}
}
2.entity类配置
@TableName(value = "表名", autoResultMap = true)
public class demo{
@TableField(typeHandler = BigDecimalListTypeHandler.class)
private List<BigDecimal> bigDecimals;
}
3.数据格式
115,120,125,12,15,12