MyBatis實(shí)現(xiàn)簡(jiǎn)單的數(shù)據(jù)表分月存儲(chǔ)
前言
今天介紹的一個(gè)業(yè)務(wù)場(chǎng)景主要是數(shù)據(jù)表過大時(shí),需要按月份進(jìn)行分月數(shù)據(jù)存儲(chǔ)。例如用戶操作記錄表 us_record,可以按月份進(jìn)行劃分,us_record_2022_11, us_record_2022_12 等。
以下內(nèi)容是基于 SpringBoot + MyBatis實(shí)現(xiàn)的
一、簡(jiǎn)單的思路分析和代碼
進(jìn)行數(shù)據(jù)分月存儲(chǔ)時(shí),先要判斷進(jìn)入程序時(shí)是否已存在記錄對(duì)應(yīng)的月度表。
- 若為第一次進(jìn)入需要根據(jù)對(duì)應(yīng)的區(qū)分字符創(chuàng)建數(shù)據(jù)表
- 若已創(chuàng)建記錄表,需要根據(jù)區(qū)分字符動(dòng)態(tài)插入數(shù)據(jù)
1.1 判斷是否存在對(duì)應(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ù)庫(kù)中不存在,則新建對(duì)應(yīng)的表
usDataRecordMapper.createTable(tableName);
}
如何判斷數(shù)據(jù)庫(kù)中是否存在某張表
編寫接口定義
// database:對(duì)應(yīng)的數(shù)據(jù)庫(kù) table:對(duì)應(yīng)的表名
int countTableNum(@Param("database") String database, @Param("table") String table);
編寫sql 實(shí)現(xiàn) (對(duì)應(yīng)的數(shù)據(jù)庫(kù)下有多少個(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)建對(duì)應(yīng)的數(shù)據(jù)庫(kù)表
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í)長(zhǎng)',
? ? ? ? ? `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ù)月份插入對(duì)應(yīng)的用戶相關(guān)記錄表 UsDataRecord:對(duì)應(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: 判斷是否存在對(duì)應(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ù)庫(kù)中不存在,則新建對(duì)應(yīng)的表
? ?// Step2: 創(chuàng)建對(duì)應(yīng)數(shù)據(jù)的月度表?? ?
? ?usDataRecordMapper.createTable(tableName);
}
// Step3: 往對(duì)應(yīng)月度表插入數(shù)據(jù)
usDataRecordMapper.insertData(usDataRecord, tableName);到此這篇關(guān)于MyBatis實(shí)現(xiàn)簡(jiǎn)單的數(shù)據(jù)表分月存儲(chǔ)的文章就介紹到這了,更多相關(guān)MyBatis 數(shù)據(jù)表分月存儲(chǔ)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MyBatis中使用foreach循環(huán)的坑及解決
這篇文章主要介紹了MyBatis中使用foreach循環(huán)的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
Apache?Arrow?Parquet存儲(chǔ)與使用
這篇文章主要為大家介紹了Apache?Arrow?Parquet存儲(chǔ)與使用原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
SpringBoot同一個(gè)方法操作多個(gè)數(shù)據(jù)源保證事務(wù)一致性
本文探討了在Spring Boot應(yīng)用中,如何在同一個(gè)方法中操作多個(gè)數(shù)據(jù)源并保證事務(wù)的一致性,由于聲明式事務(wù)的限制,直接使用@Transactional注解無法滿足需求,文章介紹了解決方案:編程式事務(wù),它允許在代碼級(jí)別更靈活地管理事務(wù),確保多數(shù)據(jù)源操作的事務(wù)一致性2024-11-11
基于mybatis-plus QueryWrapper 排序的坑
這篇文章主要介紹了mybatis-plus QueryWrapper 排序的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
IDEA設(shè)置JVM可分配內(nèi)存大小和其他參數(shù)的教程
這篇文章主要介紹了IDEA設(shè)置JVM可分配內(nèi)存大小和其他參數(shù)的教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01
詳解簡(jiǎn)單基于spring的redis配置(單機(jī)和集群模式)
這篇文章主要介紹了詳解簡(jiǎn)單基于spring的redis配置(單機(jī)和集群模式),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-02-02
Java中的使用及連接Redis數(shù)據(jù)庫(kù)(附源碼)
這篇文章主要介紹了Java中的使用及連接Redis數(shù)據(jù)庫(kù)(附源碼),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
springboot2.6.4集成swagger3.0遇到的坑及解決方法
這篇文章主要介紹了springboot2.6.4如何集成swagger3.0,在集成的過程中遇到很多問題,本文給大家分享四種問題及相應(yīng)的解決方案,需要的朋友可以參考下2022-03-03

