ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

MyBatisPlus 日常使用

2022-08-22 09:34:43  阅读:189  来源: 互联网

标签:MyBatisPlus 删除 private 添加 日常 使用 Date metaObject public


1.maven引入 

<!--mybatis-plus-->

        <dependency>

            <groupId>com.baomidou</groupId>

            <artifactId>mybatis-plus-boot-starter</artifactId>

            <version>3.0.5</version>

        </dependency>

 

2.配置文件增加日志信息

mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

3.实体和接口如:

@Data

public class User {

    private Long id;

    private String name;

    private Integer age;

    private String email;

}

@Repository

public interface UserMapper extends BaseMapper<User> {

}

注意:启动类需加扫描包

@SpringBootApplication

@MapperScan("com.atguigu.mybatisplus.mapper")

public class MybatisPlusApplication {

    public static void main(String[] args) {

        SpringApplication.run(MybatisPlusApplication.class,args);

    }

}

4.MP实现自动填充

如:默认字段

private Date createTime;

private Date updateTime;

(2)添加注解

@TableField(fill = FieldFill.INSERT)

private Date createTime;

@TableField(fill = FieldFill.INSERT_UPDATE)

private Date updateTime;

 

增加扫描配置类

@Component

public class MyMetaObjectHandler  implements MetaObjectHandler {

    @Override

    public void insertFill(MetaObject metaObject) {

        this.setFieldValByName("createTime",new Date(),metaObject);

        this.setFieldValByName("updateTime",new Date(),metaObject);

    }

 

    @Override

    public void updateFill(MetaObject metaObject) {

        this.setFieldValByName("updateTime",new Date(),metaObject);

    }

}

测试一下

 

 

 

5、乐观锁

 所谓乐观锁,就是表字段中加入版本字段,每次修改时,带着版本字段做条件,修改成功后,版本号,会进行叠加。

(1)增加字段

private Integer version;

(2)添加注解实现自动填充

 

 

(3)添加乐观锁注解

 

(4)添加插件

@Configuration

@EnableTransactionManagement

@MapperScan("com.atguigu.mybatisplus.mapper")

public class MybatisPlusConfig {

    /**

     * 乐观锁插件

     */

    @Bean

    public OptimisticLockerInterceptor optimisticLockerInterceptor() {

        return new OptimisticLockerInterceptor();

    }

}

6、逻辑删除

  • 物理删除:真实删除,将对应数据从数据库中删除,之后查询不到此条被删除数据
  • 逻辑删除:假删除,将对应数据中代表是否被删除字段状态修改为“被删除状态”,之后在数据库中仍旧能看到此条数据记录

    (1)修改表添加字段

     

    private Integer deleted;

    (2)添加注解、实现自动填充

     

    (3)添加逻辑删除注解

     

     

     

    (4)添加配置

    mybatis-plus.global-config.db-config.logic-delete-value=1

    mybatis-plus.global-config.db-config.logic-not-delete-value=0

    (5)添加插件

    @Bean

    public ISqlInjector sqlInjector() {

        return new LogicSqlInjector();

    }

    (6)测试

  • 删除

     

    查询

     

     

     

标签:MyBatisPlus,删除,private,添加,日常,使用,Date,metaObject,public
来源: https://www.cnblogs.com/AnKangwenqiang/p/16611717.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有