欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MybatisPlus之時(shí)間處理問(wèn)題

 更新時(shí)間:2024年09月22日 10:47:42   作者:Aholic?沖沖沖  
在數(shù)據(jù)庫(kù)設(shè)計(jì)時(shí),阿里巴巴編碼規(guī)約建議使用gmt_create和gmt_modified命名時(shí)間字段,并設(shè)置為datetime類(lèi)型,本文介紹了兩種自動(dòng)填充時(shí)間字段的實(shí)現(xiàn)方式:SQL級(jí)別和代碼級(jí)別(使用MyBatis?Plus),SQL級(jí)別通過(guò)設(shè)置默認(rèn)值和更新值為CURRENT_TIMESTAMP

MybatisPlus時(shí)間處理

建表

阿里巴巴編碼規(guī)約中建議命名為gmt_create,gmt_modifie,并且類(lèi)型datetime,我們這里用create_time create_time。

-- auto-generated definition
create table user
(
    id          bigint auto_increment comment '主鍵ID'
        primary key,
    name        varchar(30)                        null comment '姓名',
    age         int                                null comment '年齡',
    email       varchar(50)                        null comment '郵箱',
    create_time datetime  null comment '創(chuàng)建時(shí)間',
    create_time datetime  null comment '更新時(shí)間'
);

方式一:SQL級(jí)別(數(shù)據(jù)庫(kù)設(shè)置)

  • create_time:

  • update_time:

官方解釋?zhuān)?/strong>

  • 此函數(shù)返回當(dāng)前數(shù)據(jù)庫(kù)系統(tǒng)時(shí)間戳,返回值的類(lèi)型為 datetime,并且不含數(shù)據(jù)庫(kù)時(shí)區(qū)偏移量。
  • CURRENT_TIMESTAMP 從運(yùn)行 SQL Server 實(shí)例的計(jì)算機(jī)的操作系統(tǒng)中獲得此值

將Default Expression設(shè)置為CURRENT_TIMESTAMP的作用:

  • 在你進(jìn)行插入、創(chuàng)建一條數(shù)據(jù)時(shí)給定一個(gè)默認(rèn)值。
  • 將On Update設(shè)置為CURRENT_TIMESTAMP的作用:
  • 在你進(jìn)行更新數(shù)據(jù)時(shí)會(huì)按照CURRENT_TIMESTAMP的規(guī)定更新你的值。(相當(dāng)于實(shí)現(xiàn)了操作后時(shí)間的自動(dòng)更新)

方式二:代碼級(jí)別(mybatisplus自動(dòng)填充)

Java中(springboot)

建一個(gè)pojo實(shí)體類(lèi):

package com.hyq.pojo;

import com.baomidou.mybatisplus.annotation.*;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.format.annotation.DateTimeFormat;

import java.util.Date;

@Data
@AllArgsConstructor
@NoArgsConstructor
@TableName("user")
public class User {
    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT)  //插入時(shí)更新
    private Date createTime;
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT_UPDATE)   //添加時(shí)更新  之后寫(xiě)策略
    private Date updateTime;


}

重點(diǎn)看時(shí)間的處理:

@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT)  //插入時(shí)更新
    private Date createTime;
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT_UPDATE)   //添加時(shí)更新  之后寫(xiě)策略
    private Date updateTime;

官方描述:

  • 描述:表名注解,標(biāo)識(shí)實(shí)體類(lèi)對(duì)應(yīng)的表
  • 使用位置:實(shí)體類(lèi)

寫(xiě)完@TableField后可以去配置一個(gè)handler我們這里取名為MyMetaObjectHandler;

實(shí)現(xiàn)元對(duì)象處理器接口:com.baomidou.mybatisplus.core.handlers.MetaObjectHandler

package com.hyq.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  //一定不要忘記把處理器加到io容器c中
public class MyMetaObjectHandler implements MetaObjectHandler {

    //插入時(shí)的填充策略
    @Override
    public void insertFill(MetaObject metaObject) {
        log.info("start insert fill......");
        this.setFieldValByName("createTime", new Date(), metaObject);
        this.setFieldValByName("updateTime", new Date(), metaObject);
    }
    //更新時(shí)的填充策略
    @Override
    public void updateFill(MetaObject metaObject) {
        log.info("start insert fill......");
        this.setFieldValByName("updateTime", new Date(), metaObject);

    }
}

這里的setFieldValByName源碼如下:

    /**
     * 通用填充
     *
     * @param fieldName  java bean property name  字段名稱(chēng)
     * @param fieldVal   java bean property value 屬性值
     * @param metaObject meta object parameter 元對(duì)象參數(shù)
     */
    default MetaObjectHandler setFieldValByName(String fieldName, Object fieldVal, MetaObject metaObject) {
        if (Objects.nonNull(fieldVal) && metaObject.hasSetter(fieldName)) {
            metaObject.setValue(fieldName, fieldVal);
        }
        return this;
    }

根據(jù)自己理解判斷該怎么用;

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 通過(guò)實(shí)例解析spring環(huán)繞通知原理及用法

    通過(guò)實(shí)例解析spring環(huán)繞通知原理及用法

    這篇文章主要介紹了通過(guò)實(shí)例解析spring環(huán)繞通知原理及用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • 一文帶你徹底理解Java序列化和反序列化

    一文帶你徹底理解Java序列化和反序列化

    這篇文章主要介紹了Java序列化和反序列化的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)Java,感興趣的朋友可以了解下
    2020-09-09
  • 實(shí)例講解Java處理PDF圖章的方法

    實(shí)例講解Java處理PDF圖章的方法

    在本篇文章里小編給大家分享了關(guān)于Java處理PDF圖章的方法,對(duì)此有需要的朋友們可以學(xué)習(xí)下。
    2019-02-02
  • 深入理解Java 線程池

    深入理解Java 線程池

    這篇文章主要介紹了Java 線程池的相關(guān)資料,文中講解非常細(xì)致,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • 深入理解springMVC中的Model和Session屬性

    深入理解springMVC中的Model和Session屬性

    這篇文章主要介紹了深入理解springMVC中的Model和Session屬性,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • java父子線程之間實(shí)現(xiàn)共享傳遞數(shù)據(jù)

    java父子線程之間實(shí)現(xiàn)共享傳遞數(shù)據(jù)

    本文介紹了Java中父子線程間共享傳遞數(shù)據(jù)的幾種方法,包括ThreadLocal變量、并發(fā)集合和內(nèi)存隊(duì)列或消息隊(duì)列,并提醒注意并發(fā)安全問(wèn)題
    2025-02-02
  • 使用java一維數(shù)組模擬壓棧彈棧

    使用java一維數(shù)組模擬壓棧彈棧

    這篇文章主要介紹了如何使用java一維數(shù)組模擬壓棧彈棧,需要的朋友可以參考下
    2021-04-04
  • 深入了解Java中的Filter過(guò)濾器

    深入了解Java中的Filter過(guò)濾器

    Filter也稱(chēng)之為過(guò)濾器,WEB開(kāi)發(fā)人員通過(guò)Filter技術(shù),對(duì)web服務(wù)器管理的所有web資源:從而實(shí)現(xiàn)一些特殊的功能。例如實(shí)現(xiàn)URL級(jí)別的權(quán)限訪問(wèn)控制、過(guò)濾敏感詞匯、壓縮響應(yīng)信息等一些高級(jí)功能。下面我們來(lái)簡(jiǎn)單學(xué)習(xí)一下吧
    2019-05-05
  • SpringBoot項(xiàng)目中使用redis緩存的方法步驟

    SpringBoot項(xiàng)目中使用redis緩存的方法步驟

    本篇文章主要介紹了SpringBoot項(xiàng)目中使用redis緩存的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • idea中service或者mapper引入報(bào)紅的問(wèn)題及解決

    idea中service或者mapper引入報(bào)紅的問(wèn)題及解決

    在使用IntelliJ IDEA開(kāi)發(fā)SpringBoot項(xiàng)目時(shí),有時(shí)會(huì)遇到Service或Mapper接口引入時(shí)報(bào)紅但不影響項(xiàng)目運(yùn)行的情況,這主要是因?yàn)镮DEA的檢查級(jí)別設(shè)置問(wèn)題,解決方法是將有問(wèn)題的Error級(jí)別改為編譯通過(guò)的安全級(jí)別,即可消除報(bào)紅
    2024-09-09

最新評(píng)論