而使用 Mybatis 的動態(tài) SQL,就能很好地為我們解決這個問題,需要的朋友可以參考下" />

欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis實現(xiàn)動態(tài)建表代碼實例

 更新時間:2023年10月17日 10:43:58   作者:yuhuofei2021  
這篇文章主要介紹了Mybatis實現(xiàn)動態(tài)建表代碼實例,解釋一下,就是指根據(jù)傳入的表名,動態(tài)地創(chuàng)建數(shù)據(jù)庫表,以供后面的業(yè)務場景使用,
而使用 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的大門-最全Maven配置及集成idea工具總結(jié)

    Maven項目對象模型(POM),是一個項目管理工具可以通過一小段描述信息來管理項目的構(gòu)建,報告和文檔的軟件.那我們想要在IDEA中使用Maven得進行一些配置,接下來我們具體看一下是如何配置使用的,需要的朋友可以參考下
    2021-06-06
  • JPA在不寫sql的情況下如何實現(xiàn)模糊查詢

    JPA在不寫sql的情況下如何實現(xiàn)模糊查詢

    文章介紹了在項目中實現(xiàn)模糊查詢的幾種方法,包括使用JPA的API、JPQL、QueryByExample和@Query注解,通過實現(xiàn)Specification接口和定義接口繼承JpaRepository,可以方便地進行單字段和多字段的模糊查詢,文章還提到了BINARY函數(shù)的使用以及查詢結(jié)果的返回
    2024-11-11
  • 基于maven的ssm框架整合的示例代碼

    基于maven的ssm框架整合的示例代碼

    本篇文章主要介紹了基于maven的ssm框架整合的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • 手工體驗smtp和pop3協(xié)議 郵件實現(xiàn)詳解(二)

    手工體驗smtp和pop3協(xié)議 郵件實現(xiàn)詳解(二)

    POP3/IMAP協(xié)議定義了郵件客戶端軟件和POP3郵件服務器的通信規(guī)則,這篇文章我們就來手工體驗SMTP和POP3協(xié)議的奧秘,感興趣的小伙伴們可以參考一下
    2017-10-10
  • 使用maven-assembly-plugin如何打包多模塊項目

    使用maven-assembly-plugin如何打包多模塊項目

    這篇文章主要介紹了使用maven-assembly-plugin如何打包多模塊項目,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Java設計模式之原型模式的示例詳解

    Java設計模式之原型模式的示例詳解

    原型模式(Prototype Pattern)指使用原型實例指定創(chuàng)建對象的種類,并且通過拷貝這些原型創(chuàng)建新的對象。本文將通過案例詳細講解一下原型模式,感興趣的可以了解一下
    2022-02-02
  • java非公平鎖知識點實例詳解

    java非公平鎖知識點實例詳解

    在本篇文章里小編給大家整理了一篇關(guān)于java非公平鎖知識點實例詳解,有興趣的朋友們可以學習參考下。
    2021-10-10
  • gradle中的增量構(gòu)建淺析

    gradle中的增量構(gòu)建淺析

    這篇文章主要介紹了gradle中的增量構(gòu)建,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • 淺析final,finally,finalize 的區(qū)別

    淺析final,finally,finalize 的區(qū)別

    以下是對final,finally,finalize的區(qū)別進行了詳細的分析介紹,需要的朋友可以過來參考下
    2013-09-09
  • 非maven項目快速轉(zhuǎn)換為maven項目的方法步驟

    非maven項目快速轉(zhuǎn)換為maven項目的方法步驟

    時候我們導入的項目并不是有maven來管理依賴的,而是要手動添加jar包,比較麻煩,本文主要介紹了非maven項目快速轉(zhuǎn)換為maven項目的方法步驟,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01

最新評論