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

mybatis-plus之如何根據(jù)數(shù)據(jù)庫主鍵定義字段類型

 更新時間:2023年07月15日 09:20:38   作者:BinaryBoss  
這篇文章主要介紹了mybatis-plus之如何根據(jù)數(shù)據(jù)庫主鍵定義字段類型問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

mybatis-plus根據(jù)數(shù)據(jù)庫主鍵定義字段類型

查看mybatis-plus源代碼IdType

package com.baomidou.mybatisplus.annotation;
public enum IdType {
? AUTO(0), ? ? ? ? ? ?//數(shù)據(jù)庫自增 依賴數(shù)據(jù)庫
? NONE(1), ? ? ? ? ? ?//表示該類型未甚至主鍵類型 (如果沒有主鍵策略)默認根據(jù)雪花算法生成
? INPUT(2), ? ? ? ? ? //用戶輸入ID(該類型可以通過自己注冊填充插件進行填充)
? //下面這三種類型,只有當插入對象id為空時 才會自動填充
? ID_WORKER(3), ? ? ? //全局唯一(idWorker)數(shù)值類型
? UUID(4), ? ? ? ? ? ?//全局唯一(UUID)
? ID_WORKER_STR(5); ? //全局唯一(idWorker的字符串表示)
? private int key;
? private IdType(int key) {
? ? this.key = key;
? }
? public int getKey() {
? ? return this.key;
? }
}

在實體類中ID屬性字段加注解

@TableId(type = IdType.AUTO) 主鍵自增 數(shù)據(jù)庫中需要設置主鍵自增
private Long id;
@TableId(type = IdType.NONE) 默認 跟隨全局策略走
private Long id;
@TableId(type = IdType.UUID) UUID類型主鍵
private Long id;
@TableId(type = IdType.ID_WORKER) 數(shù)值類型 ?數(shù)據(jù)庫中也必須是數(shù)值類型 否則會報錯
private Long id;
@TableId(type = IdType.ID_WORKER_STR) 字符串類型 ? 數(shù)據(jù)庫也要保證一樣字符類型
private Long id;
@TableId(type = IdType.INPUT) 用戶自定義了 ?數(shù)據(jù)類型和數(shù)據(jù)庫保持一致就行
private Long id;

全局主鍵策略實現(xiàn)

在application.yml文件中進行全局設置

mybatis-plus:
? mapper-locations:
? ? - com/mp/mapper/*
? global-config:
? ? db-config:
? ? ? id-type: uuid/none/input/id_worker/id_worker_str/auto ? 表示全局主鍵都采用該策略(如果全局策略和局部策略都有設置,局部策略優(yōu)先級高)

mybatis-plus操作數(shù)據(jù)庫自增主鍵和時間字段的設置

1. 主鍵ID設置@Table(type=IdType.AUTO)后報錯,或者數(shù)據(jù)庫任然保持19位默認雪花加密

  • 沒設置數(shù)據(jù)庫主鍵ID為自增。
  • 遇到任然雪花加密的措施,網(wǎng)上說法是數(shù)據(jù)庫自增關(guān)了再開,試了沒用,直接刪表重建發(fā)現(xiàn)有用。

2.給enetity字段的時間設置自動填充

在給類型添加標簽-

@TableField(fill = FieldFill.INSERT)和 @TableField(fill = FieldFill.INSERT_UPDATE)

重寫標簽自定義實現(xiàn)類 MyMetaObjectHandler

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    private static final ZoneId ZONE_UTC = ZoneId.of("UTC");
    @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);
    }
}

3. 樂觀鎖問題

樂觀鎖十分樂觀,總是認為不會出現(xiàn)問題。無論干什么都不會去上鎖。如果出現(xiàn)問題就再測試加鎖處理。

悲觀鎖,覺得總會出問題,所以干什么都會先上鎖。

樂觀鎖實現(xiàn)方式:

  • 取出記錄時,獲取當前 version
  • 更新時,帶上這個 version
  • 執(zhí)行更新時, set version = newVersion where version = oldVersion
  • 如果 version 不對,就更新失敗

注意版本更新,改mbp版本為3.4.2即可

4.數(shù)據(jù)庫設置邏輯刪除時,注意

字段名不要叫delete,這東西在數(shù)據(jù)庫里是個關(guān)鍵字,救命。

在這里插入圖片描述

總結(jié)

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

相關(guān)文章

  • SpringBoot2整合Ehcache組件實現(xiàn)輕量級緩存管理

    SpringBoot2整合Ehcache組件實現(xiàn)輕量級緩存管理

    EhCache是一個純Java的進程內(nèi)緩存框架,具有快速、上手簡單等特點,是Hibernate中默認的緩存提供方。本文講述下SpringBoot2 整合Ehcache組件的步驟
    2021-06-06
  • Java實現(xiàn)單鏈表的各種操作

    Java實現(xiàn)單鏈表的各種操作

    本文主要對Java實現(xiàn)單鏈表的各種操作進行詳細介紹。具有很好的參考價值,需要的朋友一起來看下吧
    2016-12-12
  • Spring整合Mybatis實操分享

    Spring整合Mybatis實操分享

    這篇文章主要介紹了Spring整合Mybatis實操分享,文章首先通過介紹Mybatis的工作原理展開Spring整合Mybatis的詳細內(nèi)容,需要的小伙伴可以參考一下
    2022-04-04
  • SpringCloud?Eureka服務注冊中心應用入門詳解

    SpringCloud?Eureka服務注冊中心應用入門詳解

    這篇文章主要介紹了Spring?Cloud?Eureka服務注冊中心入門流程分析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • Elasticsearch term 查詢之精確值搜索功能實現(xiàn)

    Elasticsearch term 查詢之精確值搜索功能實現(xiàn)

    term查詢是Elasticsearch中用于精確值搜索的一種基本方式,通過了解 term 查詢的工作原理和使用方法,你可以更好地利用 Elasticsearch 進行結(jié)構(gòu)化數(shù)據(jù)的搜索和分析,本文將詳細介紹 term 查詢的工作原理、使用場景以及如何在 Elasticsearch 中應用它,感興趣的朋友一起看看吧
    2024-06-06
  • Java刪除ArrayList中的重復元素的兩種方法

    Java刪除ArrayList中的重復元素的兩種方法

    在Java編程中,ArrayList是一種常用的集合類,它允許我們存儲一組元素,在某些情況下,我們可能需要移除其中重復的元素,只保留唯一的元素,下面介紹兩種常見的刪除ArrayList中重復元素的方法,需要的朋友可以參考下
    2024-12-12
  • Java2 JDK安裝和配置教程

    Java2 JDK安裝和配置教程

    這篇文章主要為大家詳細介紹了Java2 JDK安裝和配置教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • spring event 事件異步處理方式(發(fā)布,監(jiān)聽,異步處理)

    spring event 事件異步處理方式(發(fā)布,監(jiān)聽,異步處理)

    這篇文章主要介紹了spring event 事件異步處理方式(發(fā)布,監(jiān)聽,異步處理),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 關(guān)于重寫equals()方法和hashCode()方法及其簡單的應用

    關(guān)于重寫equals()方法和hashCode()方法及其簡單的應用

    這篇文章主要介紹了關(guān)于重寫equals()方法和hashCode()方法及其簡單的應用,網(wǎng)上的知識有些可能是錯誤的,關(guān)于?equals()?方法的理解,大家討論不一樣,需要的朋友可以參考下
    2023-04-04
  • 理解zookeeper選舉機制

    理解zookeeper選舉機制

    本文主要介紹了zookeeper選舉機制的相關(guān)知識,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02

最新評論