当前位置: 首页 > news >正文

MybatisPlus入门(十)MybatisPlus-逻辑删除和多记录操作

一、Mybatis-Plus 多记录操作

        按照主键删除多条记录

List<Long> ids= Arrays.asList(new Long[]{2,3})
userDao.deleteBatchIds(ids);

示例代码如下:

    @Testvoid testDelete(){//删除指定多条数据List<Long> list = new ArrayList<>();list.add(1402551342481838081L);list.add(1402553134049501186L);list.add(1402553619611430913L);userDao.deleteBatchIds(list);}


        根据主键查询多条记录
List<Long> ids= Arrays.asList(new Long[]{2,3});
List<User> userList = userDao.selectBatchIds(ids);

示例代码如下:

    @Testvoid testDelete(){//查询指定多条数据List<Long> list = new ArrayList<>();list.add(1L);list.add(3L);list.add(4L);userDao.selectBatchIds(list);}

 二、Mybatis-Plus 逻辑删除      

        如下图,描述的是房屋中介公司销售业绩数据,右边表是人员信息,左边表是开单信息,
员工1张业绩离职了,数据不需要留了,执行了delete操作,执行完,左边表的关联数据成为垃圾数据,年底如果统计报表,如下图,已经删除了,或者是脏数据,无法读取。问题出现了,统计数据不对,日常删除操作对业务会有伤害性,会将数据从数据库中删除。

如何解决? 我们不应该删除数据,在数据后面加个字段,如果是1就代表删除了。

删除操作业务问题:业务数据从数据库中丢弃。

逻辑删除:为数据设置是否可用状态字段,删除时设置状态字段为不可用状态,数据保留在数据库中。

逻辑删除操作步骤:

步骤一、数据库表中添加逻辑删除标记字段
        数据库添加字段名 deleted  类型 int 长度 1

步骤二、实体类中添加对应字段,并设定当前字段为逻辑删除标记字段

步骤三、配置逻辑删除字面值

@Datapublic class User {private Long id;//逻辑删除字段,标记当前记录是否被删除@TableLogic(value = "0" ,delval = "1")private Integer deleted;
}

配置逻辑删除字面值全局配置:

mybatis-plus:global-config:db-config:logic-delete-field: deletedlogic-not-delete-value: 0 logic-delete-value: 1

        逻辑删除开启后,执行的删除语句变成了更新语句,操作完以后会用deleted字段值标记数据是否被删除,并且标记被删除的数据,是不参与到Mabatis-Plus的API查询的过程中的,如果想查这些数据通过自己编写SQL语句。


http://www.mrgr.cn/news/69020.html

相关文章:

  • Android OpenGL ES详解——立方体贴图
  • 【苍穹外卖】学习日志-day1
  • 堆排序法,
  • 安全见闻-泷羽sec课程笔记
  • 【CICD】CICD 持续集成与持续交付在测试中的应用
  • spi 回环
  • 使用HTML、CSS和JavaScript创建动态雪人和雪花效果
  • JVM中对象在堆中的生命周期?
  • 会话技术-JWT令牌和filter
  • 如何快速关闭Linux上的服务脚本
  • 共享经济下的SpringBoot汽车管理创新
  • 电脑屏幕录像软件哪个好?这五款屏幕录像工具实打实推荐,记录精彩的瞬间!
  • 高效建造,全新体验:气膜网球馆的革新之选—轻空间
  • SpringBoot技术下的共享汽车运营平台
  • Result和ResultCode类,用于封装后端返回给前端的数据
  • 基于Python的自然语言处理系列(57):使用最佳表示向量法实现整本书的高效摘要
  • 06 P2437 蜜蜂路线
  • HTTP 和 HTTPS 的区别 - 2024最新版前端秋招面试短期突击面试题【100道】
  • 【操作系统】死锁
  • 【详解】斜率优化 DP + 凸包
  • kettle开发-Day43-数据对比
  • java day04-面向对象基础02
  • 基于java宠物医院管理系统的设计与实现
  • bat调用Perl脚本接收不到参数
  • 让SQL更优雅!深入浅出【公用表表达式(CTE)】语法及实战案例
  • ONLYOFFICE 8.2 版:助力自动化办公的佼佼者