美文网首页
ACTable开源框架的使用及异常

ACTable开源框架的使用及异常

作者: 谁在烽烟彼岸 | 来源:发表于2024-02-10 18:06 被阅读0次

介绍

ACTable是对Mybatis做的增强功能,支持SpringBoot以及传统的SpringMvc架构,配置简单,使用方便。主要是自动生成数据库表,直接修改java代码,数据库就会对应的变化,省去在调整数据库表的问题,在开发阶段非常实用。

本项目使用的springboot3.2.2版本,集成Mybatis,Mybatis-plus, ACTable组件.

配置文件:

# actable的配置信息
actable:
  table:
    auto: create
  model:
    pack: com.xxx.yours_project.*.entity
  database:
    type: mysql
  #actable.index.prefix=自己定义的索引前缀#该配置项不设置默认使用actable_idx_
  #actable.unique.prefix=自己定义的唯一约束前缀#该配置项不设置默认使用actable_uni_
  # mybatis自有的配置信息,key也可能是:mybatis.mapperLocations
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  mapper-locations: classpath*:com/gitee/sunchenbin/mybatis/actable/mapping/*/*.xml
  type-handlers-package: com.xxx.yours_project.base.util

springboot3.0以后,ACTable的自启动已经失效,先要配置主动启动:

@SpringBootApplication
@MapperScan("com.gitee.sunchenbin.mybatis.actable.dao.*")
@ComponentScan(basePackages = {"com.gitee.sunchenbin.mybatis.actable.manager.*"})
public class YywjSupportApplication {

    public static void main(String[] args) {
        ConfigurableApplicationContext run = SpringApplication.run(YywjSupportApplication.class, args);
        // 容器中获取actable的核心处理类
        StartUpHandler bean =run.getBean(StartUpHandler.class, args);
        // 手动执行actable的建表方法
        bean.startHandler();
    }
}

异常

在使用Mybatis-plus时,需要注意:

  1. 配置文件中是:mybatis-plus.mapper-locations;
  2. 在build.gradle文件中,引入的是:com.baomidou:mybatis-plus-boot-starter,而非com.baomidou:mybatis-plus
  3. 在使用自定义handle时,要注意 @MapperType,
    开始时作者使用@MappedTypes({List.class, String.class}),但是启动后报错,原因是Mybatis将这个handle滥用了,导致失败,改用@Component,项目正常启动,不再报错
    慎用@MapperType:
//@MappedTypes({List.class, String.class})
@Component
public class ListStringHandle implements TypeHandler<List<String>> {
    @Override
    public void setParameter(PreparedStatement preparedStatement, int i, List<String> strings, JdbcType jdbcType) throws SQLException {
        if (CollectionUtils.isNotEmpty(strings)) {
            preparedStatement.setString(i, strings.stream().collect(Collectors.joining(",")));
        } else {
            preparedStatement.setString(i, null);
        }
    }

    @Override
    public List<String> getResult(ResultSet resultSet, String s) throws SQLException {
        if (StringUtils.isNotEmpty(resultSet.getString(s))) {
            return Arrays.asList(resultSet.getString(s).split(","));
        }
        return null;
    }

    @Override
    public List<String> getResult(ResultSet resultSet, int i) throws SQLException {
        if (StringUtils.isNotEmpty(resultSet.getString(i))) {
            return Arrays.asList(resultSet.getString(i).split(","));
        }
        return null;
    }

    @Override
    public List<String> getResult(CallableStatement callableStatement, int i) throws SQLException {
        if (StringUtils.isNotEmpty(callableStatement.getString(i))) {
            return Arrays.asList(callableStatement.getString(i).split(","));
        }
        return null;
    }
}

相关文章

  • Azkaban的安装及使用

    LinkedIn开源的任务调度框架,Azkaban的安装及使用 Azkaban的安装https://blog.cs...

  • Fresco图片框架简介及使用

    Fresco图片框架简介及使用 Fresco是FaceBook退出了一个Android开源图片管理框架,它提供了图...

  • KSCrash崩溃收集原理浅析

    KSCrash 是一个异常收集的开源框架。 它可以捕获到Mach级内核异常、信号异常、C++异常、Objectiv...

  • 再谈JAVA注解和反射

    最近在研究阿里开源的ARouter框架,碰到了较多注解的使用。结合ButterKnife开源框架的使用,越来越体会...

  • 怎么使用腾讯QQ团队开源框架【QMUI】快速搭建高效、高性能项目

    怎么使用腾讯QQ团队开源框架【QMUI】快速搭建高效、高性能项目框架? 博爱开源框架【BAKit】怎么快速接入项目...

  • github

    简介 github是一个面向开源及私有的项目托管平台,现在所使用的各种框架及插件均可在github中找到。而且gi...

  • 如何在github中上传代码

    如何在github中上传代码 简介 github是一个面向开源及私有的项目托管平台,现在所使用的各种框架及插件均...

  • git的入门

    简介 github是一个面向开源及私有的项目托管平台,现在所使用的各种框架及插件均可在github中找到。而且gi...

  • git教程

    简介 github是一个面向开源及私有的项目托管平台,现在所使用的各种框架及插件均可在github中找到。而且gi...

  • 如何进行开源技术框架选型

    一个项目不使用开源技术框架几乎不可能,或多或少要用到一些开源技术框架。在引入新的开源框架之前需要进行选型,进行充分...

网友评论

      本文标题:ACTable开源框架的使用及异常

      本文链接:https://www.haomeiwen.com/subject/dzdradtx.html