ICode9

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

更新操作和自动填充功能

2022-05-12 16:03:02  阅读:97  来源: 互联网

标签:填充 void private 自动 更新 Date new user


更新操作

比较简单,实现原理是动态sql

    @Test
    void updateTest(){
        user user = new user();
        user.setId(1524653412236517378L);
        user.setAge(200);
        user.setEmail("2034281742@qq.com");
        userMapper.updateById(user); //没有设置ID,不知道更新哪条数据,所以一定要设置ID
    }

自动填充

这个主要用于更新时间,和创建时间等,不需要认为设置的字段

  1. 使用@TableField注解,提示plus哪写字段需要自动填充
public class user {


    @TableId(type = IdType.ID_WORKER)
    private Long id;
    private String name;
    private Integer age;
    private String email;

    @TableField(fill = FieldFill.INSERT)//填充字段,在插入时填充
    private Date createTime; //尝试驼峰命名是否可以? 可以的

    @TableField(fill = FieldFill.INSERT_UPDATE)//填充字段,在插入和更新时填充
    private Date updateTime;
}
  1. 还没完,我们只是告诉了plus哪些需要填充,但填充的数据从哪里来呢?
    这里我们可以实现MetaObjectHandler接口,来填充数据
package top.luoking.Handler;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.util.Date;

@Slf4j  //日志输出
@Component//将MyMetaObjectHandler添加到IOC容器中
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);

    }
}
  1. 测试
    @Test
    void insertTest(){
        user user = new user();
        user.setAge(21);
        user.setEmail("2034281742@qq.com");
        user.setName("小落");
        userMapper.insert(user);
    }
    @Test
    void updateTest(){
        user user = new user();
        user.setId(1524657437254115330L);
        user.setAge(200);
        user.setEmail("2034281742@qq.com");
        userMapper.updateById(user); //没有设置ID,不知道更新哪条数据,所以一定要设置ID
    }

insertTest
image
updateTest
image
达到了我们理想中的目的,在之后我们就可以利用自动填充来处理时间问题,我个人认为,蛮好用的。

标签:填充,void,private,自动,更新,Date,new,user
来源: https://www.cnblogs.com/luoking/p/16262789.html

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

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

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

ICode9版权所有