mybatisplus的邏輯刪除問題
mybatisplus的邏輯刪除
mp提供的邏輯刪除實現(xiàn)起來非常簡單
只需要在application.yml中進行邏輯刪除的相關配置即可
mybatis-plus: global-config: db-config: logic-delete-field: deleted # 全局邏輯刪除的實體字段名 logic-delete-value: 1 # 邏輯已刪除值(默認為1) logic-not-delete-value: 0 # 邏輯未刪除值(默認為0) # 若邏輯已刪除和未刪除的值和默認值一樣,則可以不配置這2項
測試代碼
int i = mapper.deleteById(6); System.out.println("rowAffected = " + i);
可以看到,發(fā)出的SQL不再是DELETE,而是UPDATE
此時我們再執(zhí)行一次SELECT
@Test public void testSelect() { List<User2> users = mapper.selectList(null); }
可以看到,發(fā)出的SQL語句,會自動在WHERE后面拼接邏輯未刪除的條件。
查詢出來的結果中,沒有了id為6的王軟蛋。
若想要SELECT的列,不包括邏輯刪除的那一列,則可以在實體類中通過@TableField進行配置
@TableField(select = false) private Integer deleted;
可以看到下圖的執(zhí)行結果中,SELECT中已經(jīng)不包含deleted這一列了
前面在application.yml中做的配置,是全局的。通常來說,對于多個表,我們也會統(tǒng)一邏輯刪除字段的名稱,統(tǒng)一邏輯已刪除和未刪除的值,所以全局配置即可。
當然,若要對某些表進行單獨配置,在實體類的對應字段上使用@TableLogic即可。
@TableLogic(value = "0", delval = "1") private Integer deleted;
【小結】
開啟mp的邏輯刪除后,會對SQL產(chǎn)生如下的影響
INSERT
語句:沒有影響SELECT
語句:追加WHERE條件,過濾掉已刪除的數(shù)據(jù)UPDATE
語句:追加WHERE條件,防止更新到已刪除的數(shù)據(jù)DELETE
語句:轉變?yōu)閁PDATE語句
注意,上述的影響,只針對mp自動注入的SQL生效。如果是自己手動添加的自定義SQL,則不會生效。
比如:
public interface User2Mapper extends BaseMapper<User2> { @Select("select * from user2") List<User2> selectRaw(); }
調用這個selectRaw,則mp的邏輯刪除不會生效。
另,邏輯刪除可在application.yml中進行全局配置,也可在實體類中用@TableLogic進行局部配置。
使用mybatisplus邏輯刪除,修改含有邏輯刪除的字段爆錯
mybatisplus在配置文件中配置如下
以上是全局邏輯刪除配置。
當使用mybatisplus生成的修改方法,修改含有showStatus對應的字段時,會報錯。
錯誤sql語句如下
而我要修改的如下:
正確的修改的sql語句應該如下:
所以我們可以在xml文件中單獨寫sql語句
或者不在配置文件中設置邏輯刪除字段名 使用@TableLogic注解
如下:
showStatus是表示此信息是否顯示。
如:
表示 show_status等于0時 brand_id (即id)=1591652104429125634 的信息不顯示。
這樣我們就是局部使用邏輯刪除。
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Spring AOP結合注解實現(xiàn)接口層操作日志記錄
在項目開發(fā)中我們需要記錄接口的操作日志:包含請求參數(shù)、響應參數(shù)、接口所屬模塊、接口功能描述、請求地址、ip地址等信息;實現(xiàn)思路很簡單就是基于注解和aop的方式去記錄日志,主要的難點在于日志表結構、注解的設計已經(jīng)aop實現(xiàn)的一些比較好的實現(xiàn)方式的借鑒2022-08-08Intellij Idea插件開發(fā)之創(chuàng)建項目層級的右鍵菜單
這篇文章主要介紹了Intellij Idea插件開發(fā)之創(chuàng)建項目層級的右鍵菜單,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-02java.net.http.HttpClient使用示例解析
這篇文章主要為大家介紹了java.net.http.HttpClient使用示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08Spring緩存注解@Cacheable @CacheEvit @CachePut使用介紹
Spring在3.1版本,就提供了一條基于注解的緩存策略,實際使用起來還是很絲滑的,本文將針對幾個常用的注解進行簡單的介紹說明,有需要的小伙伴可以嘗試一下2021-07-07IntelliJ IDEA同步代碼時版本沖突而產(chǎn)生出的incoming partial文件問題的解決辦法
今天小編就為大家分享一篇關于IntelliJ IDEA同步代碼時版本沖突而產(chǎn)生出的incoming partial文件問題的解決辦法,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10