Mybatis實現(xiàn)動態(tài)建表代碼實例
而使用 Mybatis 的動態(tài) SQL,就能很好地為我們解決這個問題,需要的朋友可以參考下
1. 前 言
在實際的開發(fā)中,有時候我們會遇到動態(tài)建表的情況,什么意思呢?
解釋一下,就是指根據(jù)傳入的表名,動態(tài)地創(chuàng)建數(shù)據(jù)庫表,以供后面的業(yè)務(wù)場景使用。
而使用 Mybatis 的動態(tài) SQL,就能很好地為我們解決這個問題。
例如,現(xiàn)在要動態(tài)地創(chuàng)建一個班級表,那么正常的數(shù)據(jù)庫語句,可能是這樣的:
CREATE TABLE `2201011` (
`class_id` int(8) NOT NULL COMMENT' 班級id',
`class_name` varchar(100) NOT NULL COMMENT '班級名稱',
`student_count` int(10) NOT NULL COMMENT '班級學(xué)生人數(shù)',
`teacher_count` int(8) NOT NULL COMMENT '班級配備教師人數(shù)',
PRIMARY KEY (`class_id`)
) ENGINE InnoDB CHARACTER SET utf8 COLLATE utf8_bin;
表名就是班級名,后面這個班級名是動態(tài)傳參的,而每個班級都是這樣的表結(jié)構(gòu)字段,那接下來,我們就用 Mybatis 的動態(tài) SQL 實現(xiàn)一下。
2. 動態(tài)建表實現(xiàn)
這里省略建立項目的過程,只寫一個動態(tài)建表的實現(xiàn)。
Mapper 層
package springboot.mybatisplus.student.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Param;
import springboot.mybatisplus.student.entity.Student;
/**
* <p>
* Mapper 接口
* </p>
*
* @author yuhuofei
* @since 2022-04-05
*/
public interface StudentMapper extends BaseMapper<Student> {
/**
* 動態(tài)建表
*
* @param tableName
* @return int
*/
int createNewTable(@Param("tableName") String tableName);
}
Mapper.xml 層
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="springboot.mybatisplus.student.mapper.StudentMapper">
<!-- 通用查詢映射結(jié)果 -->
<resultMap id="BaseResultMap" type="springboot.mybatisplus.student.entity.Student">
<id column="id" property="id"/>
<result column="name" property="name"/>
<result column="tid" property="tid"/>
</resultMap>
<!-- 通用查詢結(jié)果列 -->
<sql id="Base_Column_List">
id, name, tid
</sql>
<update id="createNewTable" parameterType="String">
CREATE TABLE ${tableName} (
class_id int(8) NOT NULL ,
class_name varchar(100) NOT NULL ,
student_count int(10) NOT NULL ,
teacher_count int(8) NOT NULL ,
PRIMARY KEY (class_id)
)ENGINE InnoDB CHARACTER SET utf8 COLLATE utf8_bin
</update>
</mapper>
到此這篇關(guān)于Mybatis實現(xiàn)動態(tài)建表代碼實例的文章就介紹到這了,更多相關(guān)Mybatis動態(tài)建表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
帶你走進(jìn)Maven的大門-最全Maven配置及集成idea工具總結(jié)
Maven項目對象模型(POM),是一個項目管理工具可以通過一小段描述信息來管理項目的構(gòu)建,報告和文檔的軟件.那我們想要在IDEA中使用Maven得進(jìn)行一些配置,接下來我們具體看一下是如何配置使用的,需要的朋友可以參考下2021-06-06
手工體驗smtp和pop3協(xié)議 郵件實現(xiàn)詳解(二)
POP3/IMAP協(xié)議定義了郵件客戶端軟件和POP3郵件服務(wù)器的通信規(guī)則,這篇文章我們就來手工體驗SMTP和POP3協(xié)議的奧秘,感興趣的小伙伴們可以參考一下2017-10-10
使用maven-assembly-plugin如何打包多模塊項目
這篇文章主要介紹了使用maven-assembly-plugin如何打包多模塊項目,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
淺析final,finally,finalize 的區(qū)別
以下是對final,finally,finalize的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-09-09
非maven項目快速轉(zhuǎn)換為maven項目的方法步驟
時候我們導(dǎo)入的項目并不是有maven來管理依賴的,而是要手動添加jar包,比較麻煩,本文主要介紹了非maven項目快速轉(zhuǎn)換為maven項目的方法步驟,具有一定的參考價值,感興趣的可以了解一下2024-01-01

