开源铱塔切换MySQL数据库启动报异常

1.错误日志:

铱塔切换数据库配置为MySQL之后,启动后报错如下:

SqlExceptionHelper - Table 'iotkit.task_info ' doesn't exist

SqlExceptionHelper - Table 'iotkit.rule_info ' doesn't exist

SqlExceptionHelper - Table 'iotkit.device_info ' doesn't exist

SqlExceptionHelper - Table 'iotkit.virtual_device' doesn't exist

2.环境:

  • JDK : corretto-11

  • iotkit-parent : V0.5.X

  • MySQL:5.5.27

3.操作:

3.1阶段一(新拉下来项目)
  1. 用IDEA打开iot-iita-core,等待项目加载完成以后,打开 maven 栏在根目录点击 install
  2. 用IDEA打开iotkit-parent,等待项目加载完成,执行maven reload all project
  3. 修改iot-starter\application.yml,注释H2配置,打开MySQL配置:
  4. 修改iot-dao\iot-data-serviceImpl-rdb\pom.xml,打开MySQL依赖(使用mysql-connector-j)
  5. 在本地MySQL创建iotkit数据库
  6. 启动项目

结果:报错如上,有几张表未初始化成功。

3.2阶段二(执行完阶段一后)

  1. 删除.init和elasticsearch(iotkit.mv.db、iotkit.trace.db文件未找到)
  2. 清除数据库
  3. 重启项目

结果:报错如上,有几张表未初始化成功。

4.分析

根据报错日志,可知是表未创建成功。

5.原因

代码中的主键生成策略为整型的,不适用于String类型的主键,导致创建表失败

6.解决方案

将iotkit-parent\iot-dao\iot-data-serviceImpl-rdb\src\main\java\cc\iotkit\data\model目录下,所有Tb开头的类,主键类型为String类型的,主键生成策略修改为UUID

java 复制代码
	@Id
	@GeneratedValue(generator = "UUID")
	@GenericGenerator(name = "UUID", strategy = "org.hibernate.id.UUIDGenerator")
	@Column(length = 36)
	@ApiModelProperty(value = "主键")
	private String id;

重新删除.init文件夹,清空iotkit数据库,重启项目,所有表都创建成功!

相关推荐
大飞哥~BigFei几秒前
rabbitmq-spring-boot-start2.0.0重磅重构升级
java·重构·rabbitmq
2501_94198205几秒前
高可靠API架构的三大核心支柱
java·大数据·spring
努力也学不会java2 分钟前
【docker】Docker Image(镜像)
java·运维·人工智能·机器学习·docker·容器
豐儀麟阁贵5 分钟前
9.2连接字符串
java·开发语言·算法
浩瀚地学5 分钟前
【Java】方法
java·开发语言·经验分享·笔记
E_ICEBLUE6 分钟前
使用 Java 将 PowerPoint 转换为 PDF 的完整指南
java·开发语言·pdf·powerpoint·ppt
卿雪8 分钟前
MySQL【数据类型】:CHAR 和 VARCHAR 的对比、VATCHAR(n) 和 INT(n) 里的 n 一样吗?
android·java·数据库·python·mysql·adb·golang
李贺梖梖9 分钟前
day03 流程控制语句结构、输入
java
yellowCodeRabbit10 分钟前
最近整理了套 Java 题库,还顺手搞了个刷题应用…
java·开发语言·资料
Zzzzzxl_13 分钟前
互联网大厂Java/Agent面试实战:AIGC内容社区场景下的技术问答(含RAG/Agent/微服务/向量搜索)
java·spring boot·redis·ai·agent·rag·microservices