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為當前頁數(shù),size為每頁最大記錄數(shù) Page<User> pageUser = new Page<>(1, 5); // 調(diào)用分頁查詢方法,傳入分頁對象-pageUser,wrapper是構(gòu)造條件對象,這里暫時寫null userMapper.selectPage(pageUser, null); System.out.println("當前頁:"+ pageUser.getCurrent()); System.out.println("當前頁數(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é)果:
當前頁:1 當前頁數(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ù)記錄,只是通過一個字段去標識出這條記錄被刪除了,比如deleted
,0表示未刪除,1表示已刪除。
1、在數(shù)據(jù)表增加deleted字段。
2、實體類添加注解@TableLogic
在對應實體類里增加屬性,并且加上@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ù)就默認設(shè)置0 } }
4、application.properties 加入配置(非必須)
這里默認情況下,刪除是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)分頁邏輯刪除的詳細內(nèi)容,更多關(guān)于mybatis plus分頁邏輯刪除的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
MybatisPlus?LambdaQueryWrapper使用int默認值的坑及解決
這篇文章主要介紹了MybatisPlus?LambdaQueryWrapper使用int默認值的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教。2022-01-01java如何實現(xiàn)嵌套對象轉(zhuǎn)大map(扁平化)
這篇文章主要介紹了java如何實現(xiàn)嵌套對象轉(zhuǎn)大map(扁平化),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10SpringBoot框架實現(xiàn)切換啟動開發(fā)環(huán)境和測試環(huán)境
這篇文章主要介紹了SpringBoot框架實現(xiàn)切換啟動開發(fā)環(huán)境和測試環(huán)境,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12SpringBoot全局配置long轉(zhuǎn)String丟失精度問題解決方案
這篇文章主要介紹了SpringBoot全局配置long轉(zhuǎn)String丟失精度問題解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-08-08SpringBoot整合數(shù)據(jù)庫訪問層的實戰(zhàn)
本文主要介紹了SpringBoot整合數(shù)據(jù)庫訪問層的實戰(zhàn),主要包含JdbcTemplate和mybatis框架的整合應用,具有一定的參考價值,感興趣的可以了解一下2022-03-03Java EasyExcel實現(xiàn)導出多sheet并設(shè)置單元格樣式
EasyExcel是一個基于Java的、快速、簡潔、解決大文件內(nèi)存溢出的Excel處理工具,下面我們就來學習一下EasyExcel如何實現(xiàn)導出多sheet并設(shè)置單元格樣式吧2023-11-11