Mybatis动态创建表

背景:

项目中涉及存储数据量过大,会导致数据读取慢等问题,所以考虑动态创建表来存储数据。

这里场景动态创建表,而且字段是不固定的。表名和字段对应关系存储在单张表中!

解释:

创建表涉及到数据类型、存储长度等,这里可以根据个人业务设置、或者固定
使用Mybatis 动态sql,传入对应的数据类型来实现动态创建表

注意点:

这里简单说下表名、字段等规范
1.因为我这里表名也是动态生成,不建议纯数字,否者插入时,表名需添加~~(Table键上面),可以拼接字符前缀
2.建表时建议采用innodb引擎,一般情况。
3.数据类型的话,根据业务场景来,我这里就是int、varchar、datetime三种类型

具体实现:

1、拼接每个字段对应数据类型、长度、默认值等
对应数据也可以全varchar,根据业务需求

for (TemplateField field : fields) {
                TableParam tableParam2 = new TableParam();
                tableParam2.setField(field.getDataIndex())
                        .setContent(field.getTitle());
                if ("1".equals(field.getDataType())) {
                    tableParam2.setType(" varchar(255) ")
                            .setAttribute(" CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL ");
                }
                if ("2".equals(field.getDataType())) {
                    tableParam2.setType(" int(10) ")
                            .setAttribute(" NULL DEFAULT NULL ");
                }
                if ("3".equals(field.getDataType())) {
                    tableParam2.setType(" datetime(0) ")
                            .setAttribute(" NULL DEFAULT NULL ");
                }
                tableParamList.add(tableParam2);
            }

2、对应mapper,sql语句

    <!--创建表-->
    <update id="createTable" parameterType="java.util.List" statementType="STATEMENT">
        CREATE TABLE `${tableName}`
        (
        <foreach collection="tableParams" separator="," item="item">
            `${item.field}` ${item.type} ${item.attribute} COMMENT '${item.content}'
        </foreach>
        ${key}
        )
        ENGINE = InnoDB AUTO_INCREMENT = 1  CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '模板对应数据填报表' ROW_FORMAT = Dynamic;
    </update>

到此,Mybatis动态创建表就可以了!

–End

  • 4
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
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动态创建表

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值