Mybatis动态创建数据库表

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

  • 7
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MyBatis是一个支持动态创建的Java持久层框架,而Spring Boot是一个用于快速开发Java应用程序的框架。下面是一个简单的示例,展示了如何在Spring Boot项目中使用MyBatis动态创建。 首先,我们需要在pom.xml文件中添加MyBatis数据库驱动的依赖。可以根据自己使用的数据库类型进行相应的配置。 ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.0</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.21</version> </dependency> ``` 接下来,我们需要创建一个实体类来示要创建的及其字段。可以在该类上使用注解来指定名和字段名。 ```java @Entity @Table(name = "my_table") // 名 public class MyTable { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; // 省略getter和setter } ``` 然后,创建一个Mapper接口,用来定义与数据库交互的接口方法。可以使用@Mapper注解标记这个接口,让MyBatis扫描到它。 ```java @Mapper public interface MyTableMapper { @CreateTable // 自定义注解,用来标记动态创建的方法 @Insert("CREATE TABLE my_table (id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(255))") void createTable(); } ``` 在启动类中,使用@MapperScan注解来扫描Mapper接口,并在创建数据库连接的配置文件中添加@EnableTransactionManagement注解,以支持事务。 ```java @SpringBootApplication @MapperScan("com.example.mapper") @EnableTransactionManagement public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } } ``` 最后,创建一个自定义注解@CreateTable,用来标记动态创建的方法。 ```java @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface CreateTable { } ``` 在Mapper接口的实现类中,可以使用@Around注解拦截所有带有@CreateTable注解的方法,并在方法执行前、执行后执行相应的逻辑。在执行前,可以通过MyBatis的Mapper接口对象来动态创建。 ```java @Aspect @Component public class CreateTableAspect { @Around("@annotation(com.example.annotation.CreateTable)") public Object createTable(ProceedingJoinPoint joinPoint) throws Throwable { // 获取Mapper接口对象 MyTableMapper mapper = (MyTableMapper) joinPoint.getTarget(); // 动态创建 mapper.createTable(); // 执行原方法 return joinPoint.proceed(); } } ``` 以上是一个使用MyBatis动态创建的简单示例。通过Spring Boot的整合,我们可以方便地在项目中使用MyBatis动态创建
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

懒惰的coder

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值