栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

Mybatis动态创建数据库表

Mybatis动态创建数据库表

Mybatis动态创建数据库表 描述

​ 最近实验室的项目中有的需求涉及到需要动态创建数据库表,因此我做了一个小实验,可以通过mybatis中的动态SQL去实现动态创建或删除数据库。在正文之前先介绍一下mybatis的映射配置文件中动态传递参数的两种方式:

  • #{} 占位符 对应的变量会自动加上引号
  • ${} 拼接符 对应的变量不会自动加上引号

因此在我们动态创建数据库表进行传参的时候一定要注意,我们传递的表名或者列名一定要使用${}进行传参。

基本的创建删除表

    CREATE TABLE ${tableName} (
      id bigint(20) NOT NULL AUTO_INCREMENT,
      ${name1} bigint(20) NOT NULL,
      ${name2} double NOT NULL,
      PRIMARY KEY (id))






    DROP TABLE IF EXISTS ${tableName}

在写mapper映射接口的时候要使用@Param传参

void createNewTable(@Param("tableName") String tableName,
                    @Param("name1")String name1,
                    @Param("name2")String name2);

Integer existTable(String tableName);

void dropTable(@Param("tableName")String tableName);
使用List传参动态传入列名

这里需要简单介绍一下mybatis中foreach的使用

foreach元素的属性主要有item,index,collection,open,separator,close。

  • item:表示集合中每一个元素进行迭代时的别名
  • index:指 定一个名字,用于表示在迭代过程中,每次迭代到的位置
  • open:表示该语句以什么开始
  • separator:表示在每次进行迭代之间以什么符号作为分隔符
  • close:表示以什么结束

在使用foreach的时候最关键的也是最容易出错的就是collection属性,这个属性是必须指定的,但是在不同情况 下,该属性的值是不一样的,主要有一下3种情况:

  • 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
  • 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
  • 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在MyBatis里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key.

因此在动态创建数据库表的时候我们也可以使用这种方式传参


    CREATE TABLE ${tableName} (
    id bigint(20) NOT NULL AUTO_INCREMENT,
        
            ${rowName} varchar(255) NOT NULL,
        
      PRIMARY KEY (id))

对应的接口

void createTableByList(@Param("tableName")String tableName,@Param("rowList") List rowList);

一样不要忘了@Param

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/300900.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号