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