MybatisPlus實現(xiàn)邏輯刪除功能
邏輯刪除
你有沒有見過某些網(wǎng)站進行一些刪除操作之后,你看不到記錄了但是管理員卻能夠查看到。這里就運用到了邏輯刪除。
什么是邏輯刪除?
邏輯刪除的本質(zhì)是修改操作,所謂的邏輯刪除其實并不是真正的刪除,而是在表中將對應(yīng)的是否刪除標識(deleted)或者說是狀態(tài)字段(status)做修改操作。比如0是未刪除,1是刪除。在邏輯上數(shù)據(jù)是被刪除的,但數(shù)據(jù)本身依然存在庫中。
對應(yīng)的SQL語句:
update user set deleted=1 where id =1 and deleted=0
update 表名 set deleted = 1 where id = 1;語句表示,在該表中將id為1的信息進行邏輯刪除,那么客戶端進行查詢id為1的信息,服務(wù)器就不會提供信息。倘若想繼續(xù)為客戶端提供該信息,可將 deleted 更改為 0 。
查找的話呢是通過加上條件deleted=0
select * from user where deleted=0
來自官網(wǎng)的配置,這里直接復(fù)制
第一步 添加全局配置
mybatis-plus: global-config: db-config: logic-delete-field: flag # 全局邏輯刪除的實體字段名(since 3.3.0,配置后可以忽略不配置步驟2) logic-delete-value: 1 # 邏輯已刪除值(默認為 1) logic-not-delete-value: 0 # 邏輯未刪除值(默認為 0)
第二步、在實體類上添加@TableLogic注解
@TableLogic private Integer deleted;//對應(yīng)的實體字段,實體字段需要根據(jù)數(shù)據(jù)庫字段命名
這樣就會在預(yù)編譯sql中自動給這個字段設(shè)置的值就是全局配置設(shè)置的值
當然也可以設(shè)置局部生效 單個實體生效(不推薦)只需要在注解中添加
完整的實體示例
import com.baomidou.mybatisplus.annotation.TableLogic;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
import java.time.LocalDateTime;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User implements Serializable {
private long id;
private String name;
private long age;
private String email;
private long managerId;
private LocalDateTime createTime;
private LocalDateTime updateTime;
private long version;
@TableLogic(value = "0",delval = "1") //value表示邏輯未刪除值,delval表示邏輯刪除設(shè)置的值
private long deleted;
}
當然不建議這樣操作,一般直接@TableLogic然后通過全局設(shè)置即可
測試代碼,其中的傳入的是主鍵 劉紅雨的id
import org.junit.jupiter.api.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import top.huashengshu.demo.dao.UserMapper;
@SpringBootTest
@RunWith(SpringRunner.class)
class DemoApplicationTest {
@Autowired
UserMapper userMapper;
@Test
public void deleteTest(){
int rows = userMapper.deleteById(1094592041087729666L);
System.out.println("影響行數(shù):"+rows);
}
}
執(zhí)行結(jié)果:

查看表中數(shù)據(jù):

到此這篇關(guān)于MybatisPlus實現(xiàn)邏輯刪除功能的文章就介紹到這了,更多相關(guān)MybatisPlus 邏輯刪除內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java日志框架打印應(yīng)用程序日志代碼的執(zhí)行情況分析
在配置INFO日志級別時,日志器(logger)中debug級的日志代碼仍會被執(zhí)行,只是是否輸出取決于配置的日志級別,本文基于Java 1.8、SLF4J 1.7.25和Log4j 2.20.0進行實驗,詳述了日志框架處理日志代碼的機制,感興趣的朋友一起看看吧2024-10-10
Java消息摘要算法MAC實現(xiàn)與應(yīng)用完整示例
這篇文章主要介紹了Java消息摘要算法MAC實現(xiàn)與應(yīng)用,結(jié)合完整實例形式分析了java消息摘要算法MAC的概念、原理、實現(xiàn)方法及相關(guān)操作注意事項,需要的朋友可以參考下2019-09-09
淺談java String.split丟失結(jié)尾空字符串的問題
下面小編就為大家?guī)硪黄獪\談java String.split丟失結(jié)尾空字符串的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02
MyBatis中${}?和?#{}?有什么區(qū)別小結(jié)
${}?和?#{}?都是?MyBatis?中用來替換參數(shù)的,它們都可以將用戶傳遞過來的參數(shù),替換到?MyBatis?最終生成的?SQL?中,但它們區(qū)別卻是很大的,今天通過本文介紹下MyBatis中${}?和?#{}?有什么區(qū)別,感興趣的朋友跟隨小編一起看看吧2022-11-11
Java Properties簡介_動力節(jié)點Java學院整理
Java中有個比較重要的類Properties(Java.util.Properties),主要用于讀取Java的配置文件,各種語言都有自己所支持的配置文件,配置文件中很多變量是經(jīng)常改變的,這樣做也是為了方便用戶,讓用戶能夠脫離程序本身去修改相關(guān)的變量設(shè)置2017-05-05

