本篇內容主要講解 mybatis plus
如何更新欄位為 null
,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習 mybatis plus
如何更新欄位為 null
吧!
mybatis plus
將欄位更新為 null
,預設如果不做任何處理,使用 mybatis plus
自帶的更新方法是不能將欄位更新為 null
的,如果要將欄位更新為 null
,需要做下面的處理
在需要的欄位上加 @TableField
註解,並設定屬性
updateStrategy = FieldStrategy.IGNORED
測試程式碼如下
實體類
package com.sbmp.bean;
import java.time.LocalDate;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;
@Data
public class Userinfo {
/**
* 主鍵id
*/
@TableId(type = IdType.AUTO)
private Integer id;
/**|
* 姓名
*/
private String name;
/**
* 生日
*/
private LocalDate birthday;
}
controller
package com.sbmp.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.sbmp.bean.Userinfo;
import com.sbmp.mapper.UserinfoMapper;
@RestController
public class UserinfoController {
@Autowired
private UserinfoMapper userinfoMapper;
@RequestMapping("/info")
public String info() {
Userinfo info = new Userinfo();
info.setId(1);
info.setBirthday(null);
info.setName("薛寶釵");
userinfoMapper.updateById(info);
return "成功";
}
}
執行測試
看能不能將薛寶釵的生日更新為空
看列印的 sql 是沒有birthday = null 的拼接的,這就是預設的情況
如果想拼接 birthday = null,需要在 birthday 欄位上新增這個配置
@TableField(updateStrategy = FieldStrategy.IGNORED)
修改後的程式碼如下
@Data
public class Userinfo {
/**
* 主鍵id
*/
@TableId(type = IdType.AUTO)
private Integer id;
/**|
* 姓名
*/
private String name;
/**
* 生日
*/
@TableField(updateStrategy = FieldStrategy.IGNORED)
private LocalDate birthday;
}
執行測試
這次 birthday = null 成功更新
@TableField 部分屬性說明
看官方文件 updateStrategy 處理更新的情況;同理,新增的時候使用 insertStrategy;
涉及where條件處理使用 whereStrategy
FieldStrategy 說明
原文連結
mybatis plus如何更新欄位為null - 開發技術 - 億速雲 (yisu.com)
本作品採用《CC 協議》,轉載必須註明作者和本文連結