Mybatis實(shí)現(xiàn)動(dòng)態(tài)建表代碼實(shí)例
而使用 Mybatis 的動(dòng)態(tài) SQL,就能很好地為我們解決這個(gè)問(wèn)題,需要的朋友可以參考下
1. 前 言
在實(shí)際的開發(fā)中,有時(shí)候我們會(huì)遇到動(dòng)態(tài)建表的情況,什么意思呢?
解釋一下,就是指根據(jù)傳入的表名,動(dòng)態(tài)地創(chuàng)建數(shù)據(jù)庫(kù)表,以供后面的業(yè)務(wù)場(chǎng)景使用。
而使用 Mybatis 的動(dòng)態(tài) SQL,就能很好地為我們解決這個(gè)問(wèn)題。
例如,現(xiàn)在要?jiǎng)討B(tài)地創(chuàng)建一個(gè)班級(jí)表,那么正常的數(shù)據(jù)庫(kù)語(yǔ)句,可能是這樣的:
CREATE TABLE `2201011` (
`class_id` int(8) NOT NULL COMMENT' 班級(jí)id',
`class_name` varchar(100) NOT NULL COMMENT '班級(jí)名稱',
`student_count` int(10) NOT NULL COMMENT '班級(jí)學(xué)生人數(shù)',
`teacher_count` int(8) NOT NULL COMMENT '班級(jí)配備教師人數(shù)',
PRIMARY KEY (`class_id`)
) ENGINE InnoDB CHARACTER SET utf8 COLLATE utf8_bin;
表名就是班級(jí)名,后面這個(gè)班級(jí)名是動(dòng)態(tài)傳參的,而每個(gè)班級(jí)都是這樣的表結(jié)構(gòu)字段,那接下來(lái),我們就用 Mybatis 的動(dòng)態(tài) SQL 實(shí)現(xiàn)一下。
2. 動(dòng)態(tài)建表實(shí)現(xiàn)
這里省略建立項(xiàng)目的過(guò)程,只寫一個(gè)動(dòng)態(tài)建表的實(shí)現(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> {
/**
* 動(dòng)態(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實(shí)現(xiàn)動(dòng)態(tài)建表代碼實(shí)例的文章就介紹到這了,更多相關(guān)Mybatis動(dòng)態(tài)建表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
帶你走進(jìn)Maven的大門-最全Maven配置及集成idea工具總結(jié)
Maven項(xiàng)目對(duì)象模型(POM),是一個(gè)項(xiàng)目管理工具可以通過(guò)一小段描述信息來(lái)管理項(xiàng)目的構(gòu)建,報(bào)告和文檔的軟件.那我們想要在IDEA中使用Maven得進(jìn)行一些配置,接下來(lái)我們具體看一下是如何配置使用的,需要的朋友可以參考下2021-06-06
JPA在不寫sql的情況下如何實(shí)現(xiàn)模糊查詢
文章介紹了在項(xiàng)目中實(shí)現(xiàn)模糊查詢的幾種方法,包括使用JPA的API、JPQL、QueryByExample和@Query注解,通過(guò)實(shí)現(xiàn)Specification接口和定義接口繼承JpaRepository,可以方便地進(jìn)行單字段和多字段的模糊查詢,文章還提到了BINARY函數(shù)的使用以及查詢結(jié)果的返回2024-11-11
手工體驗(yàn)smtp和pop3協(xié)議 郵件實(shí)現(xiàn)詳解(二)
POP3/IMAP協(xié)議定義了郵件客戶端軟件和POP3郵件服務(wù)器的通信規(guī)則,這篇文章我們就來(lái)手工體驗(yàn)SMTP和POP3協(xié)議的奧秘,感興趣的小伙伴們可以參考一下2017-10-10
使用maven-assembly-plugin如何打包多模塊項(xiàng)目
這篇文章主要介紹了使用maven-assembly-plugin如何打包多模塊項(xiàng)目,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
java非公平鎖知識(shí)點(diǎn)實(shí)例詳解
在本篇文章里小編給大家整理了一篇關(guān)于java非公平鎖知識(shí)點(diǎn)實(shí)例詳解,有興趣的朋友們可以學(xué)習(xí)參考下。2021-10-10
淺析final,finally,finalize 的區(qū)別
以下是對(duì)final,finally,finalize的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-09-09
非maven項(xiàng)目快速轉(zhuǎn)換為maven項(xiàng)目的方法步驟
時(shí)候我們導(dǎo)入的項(xiàng)目并不是有maven來(lái)管理依賴的,而是要手動(dòng)添加jar包,比較麻煩,本文主要介紹了非maven項(xiàng)目快速轉(zhuǎn)換為maven項(xiàng)目的方法步驟,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01

