Mybatis动态创建数据库表

描述

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

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

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

基本的创建删除表

<update id="createNewTable" parameterType="String">
    CREATE TABLE ${tableName} (
      id bigint(20) NOT NULL AUTO_INCREMENT,
      ${name1} bigint(20) NOT NULL,
      ${name2} double NOT NULL,
      PRIMARY KEY (id))
</update>


<select id="existTable" parameterType="String" resultType="Integer">
    select count(*)
    from information_schema.TABLES
    where LCASE(table_name)=#{tableName}
</select>

<update id="dropTable">
    DROP TABLE IF EXISTS ${tableName}
</update>

在写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.

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

<update id="createTableByList">
    CREATE TABLE ${tableName} (
    id bigint(20) NOT NULL AUTO_INCREMENT,
        <foreach collection="rowList" item="rowName" index="index">
            ${rowName} varchar(255) NOT NULL,
        </foreach>
      PRIMARY KEY (id))
</update>

对应的接口

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

一样不要忘了@Param