当前位置: 首页 > news >正文

达梦数据库系列之Mysql项目迁移为达梦项目

达梦数据库系列之Mysql项目迁移为达梦项目

  • 1 达梦数据库安装及MySql数据迁移
  • 2 SpringBoot项目迁移
    • 2.1 驱动包引入
    • 2.2 驱动类配置
    • 2.3 数据源配置
    • 2.4 flowable迁移
      • 2.4.1 异常问题
      • 2.4.2 解决
  • 3 迁移常见问题
    • 3.1 不是 GROUP BY 表达式
      • 3.1.1 dm.ini 开启Mysql兼容模式
      • 3.1.2 修改动态会话级参数:GROUP_OPT_FLAG
    • 3.2 仅当指定列列表,且SET IDENTITY_INSERT为ON时,才能对自增列赋值
      • 3.2.1 原因
      • 3.2. 2 解决

1 达梦数据库安装及MySql数据迁移

请看笔者:《达梦数据库系列之安装及Mysql数据迁移》 文章,详细编写了达梦数据库安装及Mysql迁移的方式

2 SpringBoot项目迁移

2.1 驱动包引入

在项目Pom文件中,引入达梦的驱动包

<dependency>
    <groupId>com.dameng</groupId>
    <artifactId>DmJdbcDriver18</artifactId>
    <version>8.1.2.141</version>
</dependency>

2.2 驱动类配置

在application.yml中,找到driver-class-name配置,修改为dm.jdbc.driver.DmDriver

2.3 数据源配置

开发环境在application-dev.yml中,修改spring.datasource配置

spring:
  datasource:
    url: jdbc:dm://192.168.159.200:5236/database?schema=database&zeroDateTimeBehavior=convertToNull&useUnicode=true&characterEncoding=utf-8
    username: SYSDBA
    password: DMdb_123456

注意:通常情况下,达梦是通过创建用户的时候,同步创建模式,此时配置的账号下,只有一个模式,所以无需指定schema,但是由权限更高的账号进行连接时候,由于模式有多个,导致无法读取到所需创建的库,所以配置时候,添加schema参数,用于指定模式!

2.4 flowable迁移

2.4.1 异常问题

如果项目中有flowable工作流引擎,配置了达梦基础数据源后,启动会报错误:couldn’t deduct database type from database product name ‘DM DBMS’,此时由于flowable未配置达梦的类型的库,无法进行识别。
在这里插入图片描述

2.4.2 解决

通过源码跟踪,发现,flowable数据库类型未支持达梦类型,此时需要对该类进行覆盖,增加达梦类型即可。
在这里插入图片描述

  1. 找到org.flowable.common.engine.impl.AbstractEngineConfiguration.class,并拷贝至文本文档
  2. 在项目目录下创建一个 org.flowable.common.engine.impl.AbstractEngineConfiguration.java 的类
  3. 将第一步中拷贝的源码,粘贴到该类中,在getDefaultDatabaseTypeMappings方法末尾,return之前增加如下代码:
//该操作的的含义为,针对达梦数据库类型,按Mysql的语法进行执行
databaseTypeMappings.setProperty("DM DBMS", DATABASE_TYPE_MYSQL);

此时,再进行项目启动,发现可以正常启动。

3 迁移常见问题

3.1 不是 GROUP BY 表达式

达梦数据库使用GROUP BY时,SELECT中的非聚合列必须出现在GROUP BY后面,否则就会报 “不是 GROUP BY 表达式”的错误
官方解决方案地址:https://eco.dameng.com/document/dm/zh-cn/faq/faq-errorcode.html#[-4080]: 不是 group by 表达式

  • 方法1:修改代码,将对应SQL语句改成符合达梦默认语法(此方法开发通常不会接受);
  • 方法2:修改达梦数据库参数,兼容MySQL语法(COMPATIBLE_MODE 或 GROUP_OPT_FLAG)
    提示:Mysql也有对应的严格模式,可以进行关闭ONLY_FULL_GROUP_BY

3.1.1 dm.ini 开启Mysql兼容模式

修改dm.ini 中的COMPATIBLE_MODE为4,表示兼容mysql
COMPATIBLE_MODE:默认为0,是否兼容其他数据库模式(0:不兼容,1:兼容SQL92标准,2:部分兼容ORACLE,3:部分兼容MS SQL SERVER,4:部分兼容MYSQL,5:兼容DM6,6:部分兼容TERADATA,7:部分兼容POSTGRES)
注意:修改过后,需要重启数据库才能生效

3.1.2 修改动态会话级参数:GROUP_OPT_FLAG

执行以下Sql,即可兼容:

alter  system set 'GROUP_OPT_FLAG'=1 both;

注意:当执行了该Sql后,会在dm.ini同级目录下生成一个dm.ini.dmbak的备份文件,且里面的GROUP_OPT_FLAG 标记设置为了1,GROUP_OPT_FLAG的默认值是60,因此,达梦数据库就算重启,也能够保持设置的配置;
注:此命令不需要重启数据库,也能够立即生效,但是针对Java已连接了的会话,需要重启才能生效

3.2 仅当指定列列表,且SET IDENTITY_INSERT为ON时,才能对自增列赋值

3.2.1 原因

达梦数据库默认主键 ID 是自增的,不允许重复插入自增主键列;默认配置项 IDENTITY_INSERT 值为 OFF,即自增长列是系统自动处理的,不需要指定数值,如果对该字段指定了数值,就会报错。所以只有将 IDENTITY_INSERT 设置为 ON 时,自增长列才可以指定一个值。

3.2. 2 解决

在sql执行开始时开启可插入,在sql执行完成后再关闭:


set IDENTITY_INSERT table_test ON;
insert table_test (id,k1,k2) values (1,'v1','v2');
set IDENTITY_INSERT table_test OFF;

官方解决方案:
在这里插入图片描述
该操作是会话级的,也就代表着当前会话关闭后,该设置就不生效了;根据实际情况进行评估,如果有特殊指定id插入的方式,只有单独进行处理,如果该表自增字段值是框架配置的,只是表结构创建时误操作自增,则将自增配置关闭掉即可。

相关文章:

  • 代码随想录算法训练营 | 图论 | 孤岛总面积、沉没孤岛
  • GPTs+RPA赋能智慧校园:构建下一代教育智能体的技术实践
  • RK3588开发笔记-fiq_debugger: cpu 0 not responding, reverting to cpu 3问题解决
  • Dify 开源大语言模型应用开发平台使用(二)
  • 软考高项笔记 1.1.1 信息
  • Raven: 2靶场渗透测试
  • ​Unity插件-Mirror使用方法(八)组件介绍(​Network Behaviour)
  • 【Linux】http 协议
  • 3427. 变长子数组求和
  • 【YOLO V5】目标检测 WSL2 AutoDL VScode SSH
  • 基于编译器特性浅析C++程序性能优化
  • Vue基础
  • 【Linux】自定协议和序列化与反序列化
  • 跨域-告别CORS烦恼
  • 【C++设计模式】第七篇:桥接模式(Bridge)
  • @PostConstruct注解的作用
  • 基于websocket的多用户网页五子棋 --- 测试报告
  • 小微企业友好方案:低成本智能客服系统如何落地
  • C# 基础知识总结(持续更新中...)
  • 数据仓库建模方法论:起源、发展与深度对比解析
  • 中国证券业协会修订发布《证券纠纷调解规则》
  • 思想史家陈谷嘉逝世,曾为岳麓书院当代复兴奠定重要基础
  • 昆明警方重拳打击经济领域违法犯罪:去年抓获905名嫌犯
  • 王毅谈中拉论坛十年成果
  • 人大新闻教育70年丨16759门课程里的时代密码
  • 俄乌释放停火和谈信号,克宫:将组建“相应级别”谈判代表团