0
点赞
收藏
分享

微信扫一扫

【深度学习】参数优化和训练技巧

迎月兮 2023-11-30 阅读 26

答案:4步搞定

一、修改pom.xml的MybatisPlus版本(注意版本兼容性)

    <properties>
        ...
        <!--<mybatis-plus.version>3.1.1</mybatis-plus.version>-->
        <mybatis-plus.version>3.3.0</mybatis-plus.version>
    </properties>

二、application.yml中添加逻辑删除配置

mybatis-plus:
  global-config:
    db-config:
      logic-delete-field: flag # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2) 建议字段使用deleted
      logic-delete-value: 1 # 逻辑已删除值(默认为 1) 默认可以不配
      logic-not-delete-value: 0 # 逻辑未删除值(默认为 0) 默认可以不配

三、在java实体类中增加标志位属性(private boolean deleted;)

package cc.mrbird.febs.cos.entity;

import java.time.LocalDateTime;
import java.io.Serializable;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;

/**
 * 耗材类型
 *
 * @author FanK
 */
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class ConsumableType implements Serializable {

    private static final long serialVersionUID = 1L;

    @TableId(value = "ID", type = IdType.AUTO)
    private Integer id;
    /**
     * 耗材类别名称
     */
    private String name;

    /**
     * 备注
     */
    private String content;

    /**
     * 创建时间
     */
    private String createDate;

    /**
     * 逻辑删除标志位
     */
    //@TableLogic 3.3.0 版本后 可以不配@TableLogic标签
    private boolean deleted;

}

四、在数据库表中增加标志位字段deleted(类型bit)

然后重启springboot,逻辑删除即生效

修改前

修改后:

需要注意的是,如果这个表涉及到通过mapper.xml编写的复杂查询,需要手动修改相关mapper.xml中的sql语句,否则其他业务逻辑会出现异常。

比如:

页面第一条数据在数据库中已经逻辑删除了,但是仍显示在界面上。

 需要在StockPutMapper.xml中添加查询条件:

and sp.deleted = 0

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cc.mrbird.febs.cos.dao.StockPutMapper">

    <!-- 分页获取入库记录 -->
    <select id="stockPutByPage" resultType="java.util.LinkedHashMap">
        SELECT
        sp.id,
        sp.num,
        sp.price,
        sp.custodian,
        sp.put_user AS putUser,
        sp.content,
        sp.create_date AS createDate
        FROM
        stock_put sp
        WHERE 1 = 1
        <!-- wh 添加逻辑删除后,需要增加查询条件 -->
            and sp.deleted = 0
        <if test="stockPut.num != null and stockPut.num != ''">
            AND sp.num LIKE CONCAT('%',#{stockPut.num},'%')
        </if>
        <if test="stockPut.putUser != null and stockPut.putUser != ''">
            AND sp.put_user LIKE CONCAT('%',#{stockPut.putUser},'%')
        </if>
        <if test="stockPut.custodian != null and stockPut.custodian != ''">
            AND sp.custodian LIKE CONCAT('%',#{stockPut.custodian},'%')
        </if>
    </select>
</mapper>

答案:不受影响,只要java实体类没有设置删除标志属性,mybatisplus自动生成的表操作仍按原始操作进行。比如将本例中的ConsumableType实体类,添加private boolean deleted;属性后,删除sql变为update ... set ... where ...,这时将private boolean deleted;属性注释掉,删除操作恢复为原来的 delete ... from ...。

15.扩展功能-逻辑删除_哔哩哔哩_bilibili

逻辑删除 | MyBatis-Plus

举报

相关推荐

0 条评论