当前位置: 首页 > 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-8username: SYSDBApassword: 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插入的方式,只有单独进行处理,如果该表自增字段值是框架配置的,只是表结构创建时误操作自增,则将自增配置关闭掉即可。

相关文章:

达梦数据库系列之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 修改动态…...

10个实用IntelliJ IDEA插件

精心整理了最新的面试资料和简历模板&#xff0c;有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 以下是为提升开发效率推荐的10个实用IntelliJ IDEA插件&#xff0c;涵盖代码质量、效率工具及热门框架支持&#xff1a; 一、代码质量与规范 SonarLint 实时…...

10分钟从零开始搭建机器人管理系统(飞算AI)

1. 安装插件 https://www.feisuanyz.com/ 2. Intellij IDEA中运行 创建一个BS架构的机器人远程操控系统&#xff0c;具备机器人状态及位置实时更新&#xff0c;可以实现机器人远程遥控&#xff0c;可以对机器人工作日志进行统计分析&#xff0c;以及其它管理系统的常用功能3…...

[自动驾驶-传感器融合] 多激光雷达的外参标定

文章目录 引言外参标定原理ICP匹配示例参考文献 引言 多激光雷达系统通常用于自动驾驶或机器人&#xff0c;每个雷达的位置和姿态不同&#xff0c;需要将它们的数据统一到同一个坐标系下。多激光雷达外参标定的核心目标是通过计算不同雷达坐标系之间的刚性变换关系&#xff08…...

怎么让呼叫中心支持高并发

基于FreeSWITCH的呼叫中心系统并发性能优化指南 在呼叫中心系统建设中&#xff0c;高并发处理能力是衡量系统稳定性和效率的核心指标。作为开源软交换平台的代表&#xff0c;FreeSWITCH凭借其线程模型和模块化架构&#xff0c;天然适合高并发场景。然而&#xff0c;实际应用中仍…...

Elasticsearch简单学习

1、依赖的导入 <!--ES依赖--> <dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId> </dependency>2、客户端链接 RestHighLevelClient client new RestHigh…...

就像BGP中的AS_PATH一样,无论路途多远,我愿意陪你一起走——基于华为ENSP的BGP的路由负载均衡及过滤深入浅出

本篇技术博文摘要 &#x1f31f; 本文内容涵盖了BGP负载均衡的基本概念、配置技巧和在实际网络中的应用&#xff0c;包括如何在华为ENSP上实现负载均衡和路由过滤。通过配置BGP的前缀列表、ACL以及路由过滤策略&#xff0c;可以实现网络流量的精确控制和优化&#xff0c;提高网…...

valgrind 检测多线程 bug,检测 并发 bug concurrent bug parallel bug

valgrind --toolhelgrind ./your_program 如果检测的对象是大型程序&#xff0c;可以设定仅在某些函数中开启 valgrind 的检测&#xff1a; Valgrind 提供了一些客户请求&#xff08;client requests&#xff09;&#xff0c;可以在代码中插入特定的宏来控制 Valgrind 的行为。…...

游戏引擎学习第135天

仓库:https://gitee.com/mrxiao_com/2d_game_3 回顾 game_asset.cpp 的创建 在开发过程中&#xff0c;不使用任何现成的游戏引擎或第三方库&#xff0c;而是直接基于 Windows 进行开发&#xff0c;因为 Windows 目前仍然是游戏的标准平台&#xff0c;因此首先在这个环境中进行…...

异步操作返回原始上下文

是什么&#xff1f; 在讨论同步上下文执行回调的概念时&#xff0c;我们首先需要了解一些基本概念&#xff1a;同步与异步操作、上下文以及回调函数。 同步与异步操作&#xff1a; 同步操作是指代码按照顺序依次执行&#xff0c;每个操作必须等待前一个操作完成才能开始。这便…...

区块链中的数字签名:安全性与可信度的核心

数字签名是区块链技术的信任基石&#xff0c;它像区块链世界的身份证和防伪标签&#xff0c;确保每一笔交易的真实性、完整性和不可抵赖性。本文会用通俗的语言&#xff0c;带你彻底搞懂区块链中的数字签名&#xff01; 文章目录 1. 数字签名是什么&#xff1f;从现实世界到区块…...

vulnhub渗透日记23:bulldog

声明 文中涉及操作均来自靶机虚拟环境&#xff0c;禁止用于真实环境&#xff0c;任何未经授权的渗透测试都是违法行为&#xff01; 开搞 首先nmap扫描目标机开放端口和服务 访问80端口 扫目录撒 发现登录口 点击web-shell提示登录后才能使用 /dev/下面查看网页源码发现村咋h…...

macOS - 使用 tmux

文章目录 安装 tmux使用更多快捷键说明 安装 tmux brew install tmux使用 在终端输入 tmux 进入 tmux 界面&#xff0c;然后 输入 Control Option B 进入交互模式 输入 % 左右分栏&#xff0c;" 上下分割 上一个窗格&#xff1a;{&#xff0c;下一个&#xff1a;} PS…...

Armbian: 轻量级 ARM 设备专用 Linux 发行版全面解析

引言 在嵌入式开发和物联网&#xff08;IoT&#xff09;领域&#xff0c;选择合适的操作系统至关重要。对于 Raspberry Pi、Orange Pi、Banana Pi 以及 Rockchip、Amlogic、Allwinner 等 ARM 平台上的单板计算机&#xff08;SBC&#xff09;&#xff0c;一个高效、轻量级并且易…...

微服务通信:用gRPC + Protobuf 构建高效API

引言 在微服务架构中&#xff0c;服务之间的通信是系统设计的核心问题之一。传统的RESTful API虽然简单易用&#xff0c;但在性能、类型安全和代码生成等方面存在一定的局限性。gRPC作为一种高性能、跨语言的RPC框架&#xff0c;结合Protobuf&#xff08;Protocol Buffers&…...

Spring Boot 整合 JMS-ActiveMQ,并安装 ActiveMQ

1. 安装 ActiveMQ 1.1 下载 ActiveMQ 访问 ActiveMQ 官方下载页面&#xff0c;根据你的操作系统选择合适的版本进行下载。这里以 Linux 系统&#xff0c;Java环境1.8版本为例&#xff0c;下载 apache-activemq-5.16.7-bin.tar.gz。 1.2 解压文件 将下载的压缩包解压到指定目…...

容器 /dev/shm 泄漏学习

容器 /dev/shm 泄漏的介绍 在容器环境中&#xff0c;/dev/shm 是一个基于 tmpfs 的共享内存文件系统&#xff0c;通常用于进程间通信&#xff08;IPC&#xff09;和临时数据存储。由于其内存特性&#xff0c;/dev/shm 的大小是有限的&#xff0c;默认情况下 Docker 容器的 /de…...

Spring Boot 3.x 基于 Redis 实现邮箱验证码认证

文章目录 依赖配置开启 QQ 邮箱 SMTP 服务配置文件代码实现验证码服务邮件服务接口实现执行流程 依赖配置 <dependencies> <!-- Spring Boot Starter Web --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spr…...

车载测试:智能座舱测试中多屏联动与语音交互的挑战

智能座舱作为汽车智能化发展的核心&#xff0c;集成了多屏联动和语音交互功能&#xff0c;为驾驶员和乘客提供更便捷的体验。然而&#xff0c;这些功能的测试面临诸多挑战&#xff0c;包括多屏同步性、噪声干扰和复杂场景的处理。本文将详细分析这些挑战&#xff0c;探讨测试方…...

C/C++输入输出(1)

1.getchar和putchar 1.1getchar() 函数原型&#xff1a; 1 int getchar(void); getchar()函数返回用户从键盘输入的字符&#xff0c;使用时不带有任何参数。 程序运行到这个命令就会暂停&#xff0c;等待用户从键盘输入&#xff0c;等同于使用cin或scanf()方法读取一个字符…...

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…...

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …...

vue3 字体颜色设置的多种方式

在Vue 3中设置字体颜色可以通过多种方式实现&#xff0c;这取决于你是想在组件内部直接设置&#xff0c;还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法&#xff1a; 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...

06 Deep learning神经网络编程基础 激活函数 --吴恩达

深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...

力扣-35.搜索插入位置

题目描述 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 class Solution {public int searchInsert(int[] nums, …...

学校时钟系统,标准考场时钟系统,AI亮相2025高考,赛思时钟系统为教育公平筑起“精准防线”

2025年#高考 将在近日拉开帷幕&#xff0c;#AI 监考一度冲上热搜。当AI深度融入高考&#xff0c;#时间同步 不再是辅助功能&#xff0c;而是决定AI监考系统成败的“生命线”。 AI亮相2025高考&#xff0c;40种异常行为0.5秒精准识别 2025年高考即将拉开帷幕&#xff0c;江西、…...

Spring AOP代理对象生成原理

代理对象生成的关键类是【AnnotationAwareAspectJAutoProxyCreator】&#xff0c;这个类继承了【BeanPostProcessor】是一个后置处理器 在bean对象生命周期中初始化时执行【org.springframework.beans.factory.config.BeanPostProcessor#postProcessAfterInitialization】方法时…...

leetcode_69.x的平方根

题目如下 &#xff1a; 看到题 &#xff0c;我们最原始的想法就是暴力解决: for(long long i 0;i<INT_MAX;i){if(i*ix){return i;}else if((i*i>x)&&((i-1)*(i-1)<x)){return i-1;}}我们直接开始遍历&#xff0c;我们是整数的平方根&#xff0c;所以我们分两…...

【1】跨越技术栈鸿沟:字节跳动开源TRAE AI编程IDE的实战体验

2024年初&#xff0c;人工智能编程工具领域发生了一次静默的变革。当字节跳动宣布退出其TRAE项目&#xff08;一款融合大型语言模型能力的云端AI编程IDE&#xff09;时&#xff0c;技术社区曾短暂叹息。然而这一退场并非终点——通过开源社区的接力&#xff0c;TRAE在WayToAGI等…...

raid存储技术

1. 存储技术概念 数据存储架构是对数据存储方式、存储设备及相关组件的组织和规划&#xff0c;涵盖存储系统的布局、数据存储策略等&#xff0c;它明确数据如何存储、管理与访问&#xff0c;为数据的安全、高效使用提供支撑。 由计算机中一组存储设备、控制部件和管理信息调度的…...