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

达梦数据库系列之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插入的方式,只有单独进行处理,如果该表自增字段值是框架配置的,只是表结构创建时误操作自增,则将自增配置关闭掉即可。


http://www.kler.cn/a/568773.html

相关文章:

  • 基于html的俄罗斯方块小游戏(附程序)
  • 技术问题汇总:前端怎么往后端传一个数组?
  • DeepSeek 与大数据治理:AI 赋能数据管理的未来
  • 第十五届蓝桥杯最后一题 拔河问题
  • 各种传参形式
  • 深入探索 STM32 微控制器:从基础到实践
  • 每日一题——接雨水
  • 2.Exercise
  • 关于时间序列预测
  • 3.16 AI Agent 技术全景解析:从核心能力到企业级应用实践
  • GPT-4.5震撼登场,AI世界再掀波澜!(3)
  • Tkinter和爬虫写的知乎回答下载exe【免费下载】
  • 【STM32F103ZET6——库函数】6.PWM
  • 【软件安装】非华为手机安装华为电脑管家(14.0.5.8 C233)(附带安装包下载地址)
  • 蜈蚣博弈(Centipede Game)
  • Oracle性能调优(一):时间模型统计
  • 类似ComfyUI和Midjourney这样的文生图图生图应用的API与服务架构该怎么设计
  • 算法1-2 分数线划定
  • 【蓝桥杯集训·每日一题2025】 AcWing 5437. 拐杖糖盛宴 python
  • 【力扣】2626. 数组归约运算——认识循环