Mybatis如何動(dòng)態(tài)創(chuàng)建表
背景
項(xiàng)目中涉及存儲(chǔ)數(shù)據(jù)量過大,會(huì)導(dǎo)致數(shù)據(jù)讀取慢等問題,所以考慮動(dòng)態(tài)創(chuàng)建表來存儲(chǔ)數(shù)據(jù)。
↓
這里場景動(dòng)態(tài)創(chuàng)建表,而且字段是不固定的。表名和字段對(duì)應(yīng)關(guān)系存儲(chǔ)在單張表中!
解釋
創(chuàng)建表涉及到數(shù)據(jù)類型、存儲(chǔ)長度等,這里可以根據(jù)個(gè)人業(yè)務(wù)設(shè)置、或者固定
使用Mybatis 動(dòng)態(tài)sql,傳入對(duì)應(yīng)的數(shù)據(jù)類型來實(shí)現(xiàn)動(dòng)態(tài)創(chuàng)建表
注意點(diǎn):
這里簡單說下表名、字段等規(guī)范
- 1.因?yàn)槲疫@里表名也是動(dòng)態(tài)生成,不建議純數(shù)字,否者插入時(shí),表名需添加~~(Table鍵上面),可以拼接字符前綴
- 2.建表時(shí)建議采用innodb引擎,一般情況。
- 3.數(shù)據(jù)類型的話,根據(jù)業(yè)務(wù)場景來,我這里就是int、varchar、datetime三種類型
具體實(shí)現(xiàn)
1、拼接每個(gè)字段對(duì)應(yīng)數(shù)據(jù)類型、長度、默認(rèn)值等
對(duì)應(yīng)數(shù)據(jù)也可以全varchar,根據(jù)業(yè)務(wù)需求
for (TemplateField field : fields) {
TableParam tableParam2 = new TableParam();
tableParam2.setField(field.getDataIndex())
.setContent(field.getTitle());
if ("1".equals(field.getDataType())) {
tableParam2.setType(" varchar(255) ")
.setAttribute(" CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL ");
}
if ("2".equals(field.getDataType())) {
tableParam2.setType(" int(10) ")
.setAttribute(" NULL DEFAULT NULL ");
}
if ("3".equals(field.getDataType())) {
tableParam2.setType(" datetime(0) ")
.setAttribute(" NULL DEFAULT NULL ");
}
tableParamList.add(tableParam2);
}
2、對(duì)應(yīng)mapper,sql語句
<!--創(chuàng)建表-->
<update id="createTable" parameterType="java.util.List" statementType="STATEMENT">
CREATE TABLE `${tableName}`
(
<foreach collection="tableParams" separator="," item="item">
`${item.field}` ${item.type} ${item.attribute} COMMENT '${item.content}'
</foreach>
${key}
)
ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '模板對(duì)應(yīng)數(shù)據(jù)填報(bào)表' ROW_FORMAT = Dynamic;
</update>
到此,Mybatis動(dòng)態(tài)創(chuàng)建表就可以了!
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java中stream處理中map與flatMap的比較和使用案例
這篇文章主要介紹了Java中stream處理中map與flatMap的比較和使用案例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
mongo分布式鎖Java實(shí)現(xiàn)方法(推薦)
下面小編就為大家?guī)硪黄猰ongo分布式鎖Java實(shí)現(xiàn)方法(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
Java基于面向?qū)ο髮?shí)現(xiàn)一個(gè)戰(zhàn)士小游戲
這篇文章主要為大家詳細(xì)介紹了Java如何基于面向?qū)ο髮?shí)現(xiàn)一個(gè)戰(zhàn)士小游戲,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以動(dòng)手嘗試一下2022-07-07
Springboot從配置文件properties讀取字符串亂碼的解決
這篇文章主要介紹了Springboot從配置文件properties讀取字符串亂碼的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
Spring cloud 查詢返回廣告創(chuàng)意實(shí)例代碼
在本篇文章里小編給大家整理的是關(guān)于Spring cloud 查詢返回廣告創(chuàng)意實(shí)例代碼,需要的朋友們可以跟著學(xué)習(xí)下。2019-08-08
Springboot之修改啟動(dòng)端口的兩種方式(小結(jié))
這篇文章主要介紹了Springboot之修改啟動(dòng)端口的兩種方式(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
關(guān)于在Springboot中集成unihttp后應(yīng)用無法啟動(dòng)的解決辦法
本文主要介紹了在SpringBoot項(xiàng)目中集成UniHttp框架時(shí)遇到的無法啟動(dòng)問題,并提供了解決方法,作者通過詳細(xì)記錄和分析問題,希望為其他開發(fā)者提供有價(jià)值的參考和借鑒,感興趣的朋友跟隨小編一起看看吧2025-03-03

