mybatis?plus實現(xiàn)分頁邏輯刪除
一、分頁
通過mybatis-plus實現(xiàn)分頁,也是很簡單,插件大法。
1、配置分頁插件
把分頁的插件也配置到統(tǒng)一的配置類里:
@Configuration
// 配置掃描mapper的路徑
@MapperScan("com.pingguo.mpdemo.mapper")
public class MpConfig {
// 樂觀鎖插件
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
// 分頁插件
@Bean
public PaginationInterceptor paginationInterceptor() {
return new PaginationInterceptor();
}
}
2、使用分頁
還是在測試類中增加測試方法,這里列了常用到的方法,后面配合前端頁面做分頁功能時候,都要用上。
// 測試分頁
@Test
void testPaging() {
// 創(chuàng)建分頁對象,current為當(dāng)前頁數(shù),size為每頁最大記錄數(shù)
Page<User> pageUser = new Page<>(1, 5);
// 調(diào)用分頁查詢方法,傳入分頁對象-pageUser,wrapper是構(gòu)造條件對象,這里暫時寫null
userMapper.selectPage(pageUser, null);
System.out.println("當(dāng)前頁:"+ pageUser.getCurrent());
System.out.println("當(dāng)前頁數(shù)據(jù)list集合:" + pageUser.getRecords());
System.out.println("每頁顯示記錄數(shù):" + pageUser.getSize());
System.out.println("總記錄數(shù):" + pageUser.getTotal());
System.out.println("總頁數(shù):" + pageUser.getPages());
System.out.println("是否有下一頁:" + pageUser.hasNext());
System.out.println("是否有上一頁:" + pageUser.hasPrevious());
}
目前數(shù)據(jù)表共12條數(shù)據(jù),運行一下,對比下結(jié)果:

當(dāng)前頁:1 當(dāng)前頁數(shù)據(jù)list集合:[User(id=2, name=修改名稱222, age=19, email=pingguotest1@pingguo.com, createTime=Thu Dec 24 23:27:20 CST 2020, updateTime=Thu Dec 24 23:27:23 CST 2020, version=null), User(id=3, name=wesson3, age=20, email=pingguotest1@pingguo.com, createTime=Wed Dec 23 23:27:32 CST 2020, updateTime=Thu Dec 24 23:27:36 CST 2020, version=null), User(id=4, name=daxiong, age=22, email=pingguotest1@pingguo.com, createTime=null, updateTime=Fri Dec 25 00:55:02 CST 2020, version=null), User(id=5, name=wesson5, age=20, email=pingguotest1@pingguo.com, createTime=null, updateTime=null, version=null), User(id=1342322873243996161, name=李白6, age=66, email=laowang@123.com, createTime=Fri Dec 25 12:14:47 CST 2020, updateTime=Fri Dec 25 15:43:11 CST 2020, version=2)] 每頁顯示記錄數(shù):5 總記錄數(shù):12 總頁數(shù):3 是否有下一頁:true 是否有上一頁:false
二、邏輯刪除
邏輯刪除并不是真正從數(shù)據(jù)表開刪除數(shù)據(jù)記錄,只是通過一個字段去標(biāo)識出這條記錄被刪除了,比如deleted,0表示未刪除,1表示已刪除。
1、在數(shù)據(jù)表增加deleted字段。

2、實體類添加注解@TableLogic
在對應(yīng)實體類里增加屬性,并且加上@TableLogic注解。為了方便,我還加了自動填充。
@Data
public class User {
@TableId(type = IdType.ID_WORKER)
private Long id;
private String name;
... ...
@TableLogic // 加上邏輯刪除注解
@TableField(fill = FieldFill.INSERT) //為了方便,加了自動填充
private Integer deleted;
}
3、自動填充(非必須)
自動填充的話,這里也需要增加:
@Component //此注解表示 將其交給spring去管理
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
this.setFieldValByName("createTime", new Date(), metaObject);
this.setFieldValByName("updateTime", new Date(), metaObject);
this.setFieldValByName("version", 0, metaObject); //為了第一次新增就設(shè)置版本值
this.setFieldValByName("deleted", 0, metaObject); //新增數(shù)據(jù)就默認(rèn)設(shè)置0
}
}
4、application.properties 加入配置(非必須)
這里默認(rèn)情況下,刪除是1,沒刪除是0。
如果你想改成別的值,那么就要在application.properties 加入配置,換成你需要設(shè)置的值。
mybatis-plus.global-config.db-config.logic-delete-value=100 mybatis-plus.global-config.db-config.logic-not-delete-value=300
5、配置插件
@Configuration
// 配置掃描mapper的路徑
@MapperScan("com.pingguo.mpdemo.mapper")
public class MpConfig {
// 樂觀鎖插件
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
... ...
// 邏輯刪除
@Bean
public ISqlInjector sqlInjector() {
return new LogicSqlInjector();
}
}
6、試一試
因為之前的數(shù)據(jù),都沒有值,我手動把id=2的設(shè)置了0,然后去刪除id=2的數(shù)據(jù)。
// 測試 邏輯刪除
@Test
void testLogicDelete() {
int result = userMapper.deleteById(2L);
System.out.println(result);
}
可以看到執(zhí)行的sql其實是個update
JDBC Connection [HikariProxyConnection@2144912729 wrapping com.mysql.cj.jdbc.ConnectionImpl@44c13103] will not be managed by Spring ==> Preparing: UPDATE user SET deleted=1 WHERE id=? AND deleted=0 ==> Parameters: 2(Long) <== Updates: 1 Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@10f19647] 1
成功更新。

7、另外
MP查詢數(shù)據(jù)的時候會自動過濾掉被邏輯刪除的數(shù)據(jù)的,不需要我們額外處理。
執(zhí)行查詢試試:
// 查詢
@Test
void findAll() {
List<User> users = userMapper.selectList(null);
System.out.println(users);
}
SELECT id,name,age,email,create_time,update_time,version,deleted FROM user WHERE deleted=0

以上就是mybatis plus實現(xiàn)分頁邏輯刪除的詳細(xì)內(nèi)容,更多關(guān)于mybatis plus分頁邏輯刪除的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
MybatisPlus?LambdaQueryWrapper使用int默認(rèn)值的坑及解決
這篇文章主要介紹了MybatisPlus?LambdaQueryWrapper使用int默認(rèn)值的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教。2022-01-01
java如何實現(xiàn)嵌套對象轉(zhuǎn)大map(扁平化)
這篇文章主要介紹了java如何實現(xiàn)嵌套對象轉(zhuǎn)大map(扁平化),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
SpringBoot框架實現(xiàn)切換啟動開發(fā)環(huán)境和測試環(huán)境
這篇文章主要介紹了SpringBoot框架實現(xiàn)切換啟動開發(fā)環(huán)境和測試環(huán)境,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
SpringBoot全局配置long轉(zhuǎn)String丟失精度問題解決方案
這篇文章主要介紹了SpringBoot全局配置long轉(zhuǎn)String丟失精度問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08
SpringBoot整合數(shù)據(jù)庫訪問層的實戰(zhàn)
本文主要介紹了SpringBoot整合數(shù)據(jù)庫訪問層的實戰(zhàn),主要包含JdbcTemplate和mybatis框架的整合應(yīng)用,具有一定的參考價值,感興趣的可以了解一下2022-03-03
Java EasyExcel實現(xiàn)導(dǎo)出多sheet并設(shè)置單元格樣式
EasyExcel是一個基于Java的、快速、簡潔、解決大文件內(nèi)存溢出的Excel處理工具,下面我們就來學(xué)習(xí)一下EasyExcel如何實現(xiàn)導(dǎo)出多sheet并設(shè)置單元格樣式吧2023-11-11

