栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

mybatis-plus入门CRUD/日志/自动填充/乐观锁

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

mybatis-plus入门CRUD/日志/自动填充/乐观锁

入门

pom.xml


    org.springframework.boot
    spring-boot-starter-jdbc


    org.springframework.boot
    spring-boot-starter-web


    com.baomidou
    mybatis-plus-boot-starter
    3.4.2



    org.projectlombok
    lombok


    mysql
    mysql-connector-java
    runtime


    org.springframework.boot
    spring-boot-starter-test
    test


    io.springfox
    springfox-swagger-common
    2.9.2

application.yml

spring:
  datasource:
    username: root
    password: 123456
    url: jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8
    driver-class-name: com.mysql.cj.jdbc.Driver

实体类

User.java

@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class User{
    @TableId(type = IdType.AUTO)//自增,注意数据库也需要设置自增
    private int id;
    @ApiModelProperty(value = "姓名",name = "name",dataType = "String",required = true)//解释,名字,类型,是否可为空
    private String name;
    private String pwd;
}

dao层Mapper接口

UserMapper.java

@Mapper
@Repository
public interface UserMapper extends baseMapper {


}

启动类下添加扫描器

@SpringBootApplication
@MapperScan("com.shuo.dao")
public class MybatisPlusApplication {

    public static void main(String[] args) {
        SpringApplication.run(MybatisPlusApplication.class, args);
    }
}

测试类

@SpringBootTest
class MybatisPlusApplicationTests {

    @Autowired
    UserMapper userMapper;

        //查
    @Test
    void contextLoads() {
        List users = userMapper.selectList(null);
        for (User user : users) {
            System.out.println(user.toString());
        }
    }
        //增
    @Test
    public void testInsert(){
        
        User user=new User();
        user.setName("冉冉");
        user.setPwd("789456");
        userMapper.insert(user);
        //contextLoads();

    }
//改
    @Test
    public void updatetest(){
        contextLoads();
        User user = new User();
        user.setId(8);
        user.setName("李明");
        user.setPwd("789798");
        userMapper.updateById(user);
        contextLoads();
    }
}

日志自带的

application.yml

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

自动填充

添加插入的时间,改变的时间

实体类

@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class User{
    @TableId(type = IdType.AUTO)//自增
    private int id;
    @ApiModelProperty(value = "姓名",name = "name",dataType = "String",required = true)//解释,名字,类型,是否可为空
    private String name;
    private String pwd;

   // @JSonField(format = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;

    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;

handler

MymetaObjectHandler.java

@Slf4j
@Component
public class MymetaObjectHandler implements metaObjectHandler {
    //插入时的填充策略
    @Override
    public void insertFill(metaObject metaObject) {

        log.info("start insert fill.....");
        this.setFieldValByName("createTime",new Date(),metaObject);
        this.setFieldValByName("updateTime",new Date(),metaObject);
    }
    //更新时的填充策略
    @Override
    public void updateFill(metaObject metaObject) {
        log.info("start update fill.....");
        this.setFieldValByName("updateTime",new Date(),metaObject);
    }
}

乐观锁

实体类新增字段version

@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class User{
    @TableId(type = IdType.AUTO)//自增
    private int id;
    @ApiModelProperty(value = "姓名",name = "name",dataType = "String",required = true)//解释,名字,类型,是否可为空
    private String name;
    private String pwd;

   // @JSonField(format = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;

    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;


    @TableField(value="version")
    @Version
    private Integer version;
}

编写config配置文件

MybatisPlusConfig.java

@EnableTransactionManagement
@Configuration
@MapperScan("com.shuo.dao")将扫描器可转移到此
public class MybatisPlusConfig {
    @Bean
    public OptimisticLockerInterceptor OptimisticLockerInnerInterceptor() {
        return new OptimisticLockerInterceptor();//名字容易出错
    }
}

乐观锁的测试

//测试乐观锁
@Test
public void testOptimisticLocker(){
    User user=userMapper.selectById(1L);
    user.setName("小白菜");
    user.setPwd("cike567");
    System.out.println(user);
    userMapper.updateById(user);
}
//乐观锁失败   多线程下失败情况
@Test
public void testOptimisticLocker2(){
    User user=userMapper.selectById(1L);
    user.setName("小土豆");
    user.setPwd("cike567");
    System.out.println(user);
    User user1 = userMapper.selectById(1L);
    user1.setName("小豆芽");
    userMapper.updateById(user1);
    userMapper.updateById(user);
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/445838.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号