Mybatis动态创建TimescaleDB数据库表

其他部分和正常关系数据库的mybatis过程一样,就是在写mapper.xml文件时需要注意一下:

这里我使用DbTable这个类存储一个表的信息,并作为parameterType传入mapper.xml。这里表名以及字段数量名称都是根据DbTable中内容而定(这里表的字段是一个timestamp类型加njsonb类型字段)。

@Data
@Slf4j
@AllArgsConstructor
public class DbTable {
	
	// 表名
    private String tableName; 
    // 表类型,Enum(项目需求,分为STAT和ALM)
    private TableType tableType;
    // 所有Json字段的名称
    private List<String> fieldList;
    // tsdb配置,包括chunk_time_interval和add_retention_policy
    private Map<String ,String> tsdbConfigMap;
    // Json字段里面的key的名称,与题目无关可忽略
    private Map<String, List<String>> jsonFieldMap;

    public DbTable(String tableName, TableType tableType, List<String> fieldList, String tsdbConfigJson, Map<String, List<String>> jsonFieldMap) throws JsonProcessingException {

        this.tableName = tableName;
        this.tableType = tableType;
        this.fieldList = fieldList;
        this.tsdbConfigMap = JacksonUtil.getInstc().json2map(tsdbConfigJson);
        this.jsonFieldMap = jsonFieldMap;
    }
}

动态表名需要xml文件使用${},而不能用#{},虽然不能防注入。

<mapper namespace="tsdb.dbcreate.mapper.InitTsdbMapper">
    <update id="initTsdb" parameterType="DbTable">
    
        CREATE EXTENSION IF NOT EXISTS timescaledb CASCADE; // 记得加这一句,否则会出现找不到tsdb中函数的错误。
        
        DROP TABLE IF EXISTS ${tableName};

        CREATE TABLE ${tableName} (
        timestamp timestamp without time zone NOT NULL,
        <foreach collection="fieldList" item="fieldName" separator="," close="">
            ${fieldName} jsonb
        </foreach>
        );

        SELECT * FROM create_hypertable('${tableName}', 'timestamp', chunk_time_interval =>INTERVAL '${tsdbConfigMap.chunkTimeInterval}');
        SELECT add_retention_policy('${tableName}', INTERVAL '${tsdbConfigMap.dropTimeInterval}');


    </update>
</mapper>

主要就是这句:CREATE EXTENSION IF NOT EXISTS timescaledb CASCADE;不加我这儿老是报错,虽然本地Psql已经CREATE EXTENSION了。

另外:我在stackoverflow网站里也发现了同样的问题,他们是对tsdb的函数加个schma前缀,如图。这里我没遇到,可以参考一下。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 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
发出的红包

打赏作者

T.Y.Bao

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

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

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

打赏作者

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

抵扣说明:

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

余额充值