Mybatis實現(xiàn)動態(tài)建表代碼實例
而使用 Mybatis 的動態(tài) SQL,就能很好地為我們解決這個問題,需要的朋友可以參考下
1. 前 言
在實際的開發(fā)中,有時候我們會遇到動態(tài)建表的情況,什么意思呢?
解釋一下,就是指根據(jù)傳入的表名,動態(tài)地創(chuàng)建數(shù)據(jù)庫表,以供后面的業(yè)務場景使用。
而使用 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 '班級學生人數(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)文章
帶你走進Maven的大門-最全Maven配置及集成idea工具總結(jié)
Maven項目對象模型(POM),是一個項目管理工具可以通過一小段描述信息來管理項目的構(gòu)建,報告和文檔的軟件.那我們想要在IDEA中使用Maven得進行一些配置,接下來我們具體看一下是如何配置使用的,需要的朋友可以參考下2021-06-06手工體驗smtp和pop3協(xié)議 郵件實現(xiàn)詳解(二)
POP3/IMAP協(xié)議定義了郵件客戶端軟件和POP3郵件服務器的通信規(guī)則,這篇文章我們就來手工體驗SMTP和POP3協(xié)議的奧秘,感興趣的小伙伴們可以參考一下2017-10-10使用maven-assembly-plugin如何打包多模塊項目
這篇文章主要介紹了使用maven-assembly-plugin如何打包多模塊項目,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03淺析final,finally,finalize 的區(qū)別
以下是對final,finally,finalize的區(qū)別進行了詳細的分析介紹,需要的朋友可以過來參考下2013-09-09非maven項目快速轉(zhuǎn)換為maven項目的方法步驟
時候我們導入的項目并不是有maven來管理依賴的,而是要手動添加jar包,比較麻煩,本文主要介紹了非maven項目快速轉(zhuǎn)換為maven項目的方法步驟,具有一定的參考價值,感興趣的可以了解一下2024-01-01