mybatis-plus中,如果資料表欄位型別與java實體欄位型別不一樣,這時就需要做型別對映與轉換了,我們一般可以實現TypeHandler介面,或者繼承抽象類BaseTypeHandler,我們下面舉例來說明一下它的使用方法。
場景
- 資料表裡欄位是varchar,java裡是List集合,例如:我的愛好標籤
- 資料表裡欄位是varchar,java裡是個Map物件,例如:我曾經居住過的地方
操作步驟
實體類
- 類註解的引數
autoResultMap = true
,它影響TypeHandler中的getResult方法的執行 - 欄位註解
@TableField(typeHandler = ListTypeHandler.class)
@Data
@TableName(value = "t_user", autoResultMap = true)
public class TUser extends BaseEntity {
private String username;
@TableField(typeHandler = MapTypeHandler.class)
private Map extensionInfo;
@TableField(typeHandler = ListTypeHandler.class)
private List<String> likeList;
}
插入方法
@Test
public void insert() {
TUser user = new TUser();
user.setUsername("lind");
user.setExtensionInfo(new HashMap() {{
put("city", "beijing");
put("area", "shijingshan");
}});
user.setLikeList(java.util.Arrays.asList("basketball", "football"));
userDao.insert(user);
}
獲取方法
@Test
public void read() {
QueryWrapper<TUser> wrapper = new QueryWrapper<>();
wrapper.lambda().eq(TUser::getCreateBy, 1);
log.info("user1:{}", userDao.selectList(wrapper));
}