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

MyBatis實(shí)現(xiàn)簡單的數(shù)據(jù)表分月存儲

 更新時(shí)間:2023年03月17日 15:56:14   作者:Stephen GS  
本文主要介紹了MyBatis實(shí)現(xiàn)簡單的數(shù)據(jù)表分月存儲,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

今天介紹的一個(gè)業(yè)務(wù)場景主要是數(shù)據(jù)表過大時(shí),需要按月份進(jìn)行分月數(shù)據(jù)存儲。例如用戶操作記錄表 us_record,可以按月份進(jìn)行劃分,us_record_2022_11, us_record_2022_12 等。
以下內(nèi)容是基于 SpringBoot + MyBatis實(shí)現(xiàn)的

一、簡單的思路分析和代碼

進(jìn)行數(shù)據(jù)分月存儲時(shí),先要判斷進(jìn)入程序時(shí)是否已存在記錄對應(yīng)的月度表。

  • 若為第一次進(jìn)入需要根據(jù)對應(yīng)的區(qū)分字符創(chuàng)建數(shù)據(jù)表
  • 若已創(chuàng)建記錄表,需要根據(jù)區(qū)分字符動態(tài)插入數(shù)據(jù)

1.1 判斷是否存在對應(yīng)的月度表

這里以年度_月份為區(qū)分

LocalDate now = LocalDate.now();
String tableName = new StringBuilder().append(" us_record").append("_").append(now.getYear()).append("_").append(now.getMonthValue()).toString();
if(usDataRecordMapper.countTableNum(DATABASE, tableName) == 0){ // 若數(shù)據(jù)庫中不存在,則新建對應(yīng)的表
      usDataRecordMapper.createTable(tableName);
}

如何判斷數(shù)據(jù)庫中是否存在某張表

編寫接口定義

// database:對應(yīng)的數(shù)據(jù)庫  table:對應(yīng)的表名
int countTableNum(@Param("database") String database, @Param("table") String table);

編寫sql 實(shí)現(xiàn) (對應(yīng)的數(shù)據(jù)庫下有多少個(gè)該名字的數(shù)據(jù)表)

<select id="countTableNum" resultType="java.lang.Integer">
    select count(*) from information_schema.TABLES t
    where t.TABLE_SCHEMA = #{database}
        and t.TABLE_NAME = #{table}
 </select>

1.2 根據(jù)月份區(qū)分創(chuàng)建表

編寫接口定義

// 按月份為后綴創(chuàng)建對應(yīng)的數(shù)據(jù)庫表
int createTable(@Param("tableName") String tableName);

編寫sql 實(shí)現(xiàn)

?<update id="createTable">
? ? ? CREATE TABLE us.${tableName}
? ? ? (
? ? ? ? ? `id` ? ? ? ? ? ? ?int(11) NOT NULL AUTO_INCREMENT,
? ? ? ? ? `app_type` ? ? ? ?int(4) NOT NULL COMMENT '來源 1:pc 3: 安卓 4: ios',
? ? ? ? ? `event_type` ? ? ?int(4) DEFAULT '1' COMMENT '事件類型 1:下載 2:視頻時(shí)長',
? ? ? ? ? `business_type` ? int(4) DEFAULT NULL COMMENT '業(yè)務(wù)類型: ?1:課程資料 2:復(fù)習(xí)資料 ?3:直播 4:錄播 5:回放',
? ? ? ? ? `online_duration` int(4) DEFAULT NULL,
? ? ? ? ? `mapping_id` ? ? ?varchar(255) NOT NULL DEFAULT '' COMMENT '關(guān)聯(lián)id',
? ? ? ? ? `user_id` ? ? ? ? varchar(150) NOT NULL DEFAULT '' COMMENT '用戶id',
? ? ? ? ? `create_time` ? ? datetime ? ? ? ? ? ? ?DEFAULT CURRENT_TIMESTAMP COMMENT '創(chuàng)建時(shí)間',
? ? ? ? ? `unit` ? ? ? ? ? ?int(4) DEFAULT NULL COMMENT '單位 : 1/次數(shù) 2/分鐘 3/秒',
? ? ? ? ? `learn_id` ? ? ? ?varchar(150) ? ? ? ? ?DEFAULT NULL,
? ? ? ? ? PRIMARY KEY (`id`)
? ? ? ) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT COMMENT='用戶相關(guān)記錄表';

? </update>

1.3 根據(jù)月份插入數(shù)據(jù)表

編寫接口定義

// 根據(jù)月份插入對應(yīng)的用戶相關(guān)記錄表 UsDataRecord:對應(yīng)的用戶操作記錄
int insertData(@Param("record") UsDataRecord usDataRecord, @Param("tableName") String tableName);

編寫sql 實(shí)現(xiàn) (根據(jù)自己的業(yè)務(wù)補(bǔ)充插入語句)

<insert id="insertData">
      insert into us.${tableName}
      ..........
 </insert>        

1.4 完整的使用流程

// Step1: 判斷是否存在對應(yīng)月度表
LocalDate now = LocalDate.now();
String tableName = new StringBuilder().append(TABLE_NAME).append("_").append(now.getYear()).append("_").append(now.getMonthValue()).toString();

if(usDataRecordMapper.countTableNum(DATABASE, tableName) == 0){ // 若數(shù)據(jù)庫中不存在,則新建對應(yīng)的表
? ?// Step2: 創(chuàng)建對應(yīng)數(shù)據(jù)的月度表?? ?
? ?usDataRecordMapper.createTable(tableName);
}

// Step3: 往對應(yīng)月度表插入數(shù)據(jù)
usDataRecordMapper.insertData(usDataRecord, tableName);

到此這篇關(guān)于MyBatis實(shí)現(xiàn)簡單的數(shù)據(jù)表分月存儲的文章就介紹到這了,更多相關(guān)MyBatis 數(shù)據(jù)表分月存儲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Struts2中異常處理機(jī)制分析

    Struts2中異常處理機(jī)制分析

    這篇文章主要介紹了Struts2中異常處理機(jī)制分析,涉及到了聲明式異常捕捉的相關(guān)內(nèi)容,以及兩種異常映射的分析,需要的朋友可以參考下。
    2017-09-09
  • Java實(shí)現(xiàn)批量導(dǎo)入excel表格數(shù)據(jù)到數(shù)據(jù)庫中的方法

    Java實(shí)現(xiàn)批量導(dǎo)入excel表格數(shù)據(jù)到數(shù)據(jù)庫中的方法

    這篇文章主要介紹了Java實(shí)現(xiàn)批量導(dǎo)入excel表格數(shù)據(jù)到數(shù)據(jù)庫中的方法,結(jié)合實(shí)例形式詳細(xì)分析了java導(dǎo)入Excel數(shù)據(jù)到數(shù)據(jù)庫的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2017-10-10
  • Java 中的vector和list的區(qū)別和使用實(shí)例詳解

    Java 中的vector和list的區(qū)別和使用實(shí)例詳解

    在大家還沒有了解vector,list,deque的知識之前,我先給大家介紹下stl,本文重點(diǎn)給大家介紹vector和list的區(qū)別及使用,感興趣的的朋友一起看看吧
    2017-09-09
  • Java實(shí)現(xiàn)員工信息管理系統(tǒng)

    Java實(shí)現(xiàn)員工信息管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)員工信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Spring?Cloud?使用?Resilience4j?實(shí)現(xiàn)服務(wù)熔斷的方法

    Spring?Cloud?使用?Resilience4j?實(shí)現(xiàn)服務(wù)熔斷的方法

    服務(wù)熔斷是為了保護(hù)我們的服務(wù),比如當(dāng)某個(gè)服務(wù)出現(xiàn)問題的時(shí)候,控制打向它的流量,讓它有時(shí)間去恢復(fù),或者限制一段時(shí)間只能有固定數(shù)量的請求打向這個(gè)服務(wù),這篇文章主要介紹了Spring?Cloud?使用?Resilience4j?實(shí)現(xiàn)服務(wù)熔斷,需要的朋友可以參考下
    2022-12-12
  • idea向System.getenv()添加系統(tǒng)環(huán)境變量的操作

    idea向System.getenv()添加系統(tǒng)環(huán)境變量的操作

    這篇文章主要介紹了idea向System.getenv()添加系統(tǒng)環(huán)境變量的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • GC算法實(shí)現(xiàn)篇之并發(fā)標(biāo)記清除

    GC算法實(shí)現(xiàn)篇之并發(fā)標(biāo)記清除

    這篇文章主要為大家介紹了GC算法實(shí)現(xiàn)篇之并發(fā)-標(biāo)記-清除,?CMS垃圾收集器在減少停頓時(shí)間上做了很多給力的工作,?大量的并發(fā)線程執(zhí)行的工作并不需要暫停應(yīng)用線程
    2022-01-01
  • Spring Boot 自定義數(shù)據(jù)源DruidDataSource代碼

    Spring Boot 自定義數(shù)據(jù)源DruidDataSource代碼

    這篇文章主要介紹了Spring Boot 自定義數(shù)據(jù)源DruidDataSource代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • SpringBoot 過濾器、攔截器、監(jiān)聽器對比及使用場景分析

    SpringBoot 過濾器、攔截器、監(jiān)聽器對比及使用場景分析

    過濾器是處于客戶端和服務(wù)器資源文件之間的一道過濾網(wǎng),這篇文章主要介紹了SpringBoot 過濾器、攔截器、監(jiān)聽器對比及使用場景分析,需要的朋友可以參考下
    2021-05-05
  • Java基礎(chǔ)泛型詳情

    Java基礎(chǔ)泛型詳情

    這篇文章主要介紹了Java基礎(chǔ)泛型詳情,泛型是JDK5中引入的特性,它提供了編譯時(shí)類型安全檢測機(jī)制,該機(jī)制允許在編譯時(shí)檢測到非法的類型,下面文章的詳細(xì)介紹,需要的朋友可以參考一下
    2022-04-04

最新評論