MyBatis實(shí)現(xiàn)簡單的數(shù)據(jù)表分月存儲
前言
今天介紹的一個(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)文章
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-10Java 中的vector和list的區(qū)別和使用實(shí)例詳解
在大家還沒有了解vector,list,deque的知識之前,我先給大家介紹下stl,本文重點(diǎn)給大家介紹vector和list的區(qū)別及使用,感興趣的的朋友一起看看吧2017-09-09Java實(shí)現(xiàn)員工信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)員工信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02Spring?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-12idea向System.getenv()添加系統(tǒng)環(huán)境變量的操作
這篇文章主要介紹了idea向System.getenv()添加系統(tǒng)環(huán)境變量的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06GC算法實(shí)現(xiàn)篇之并發(fā)標(biāo)記清除
這篇文章主要為大家介紹了GC算法實(shí)現(xiàn)篇之并發(fā)-標(biāo)記-清除,?CMS垃圾收集器在減少停頓時(shí)間上做了很多給力的工作,?大量的并發(fā)線程執(zhí)行的工作并不需要暫停應(yīng)用線程2022-01-01Spring Boot 自定義數(shù)據(jù)源DruidDataSource代碼
這篇文章主要介紹了Spring Boot 自定義數(shù)據(jù)源DruidDataSource代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10SpringBoot 過濾器、攔截器、監(jiān)聽器對比及使用場景分析
過濾器是處于客戶端和服務(wù)器資源文件之間的一道過濾網(wǎng),這篇文章主要介紹了SpringBoot 過濾器、攔截器、監(jiān)聽器對比及使用場景分析,需要的朋友可以參考下2021-05-05