命令行方式将mysql数据库迁移到达梦数据库(全步骤)

因项目需求,需要将mysql数据库转换为国产达梦数据库,但由于安全问题,正式环境只能用命令行方式连接,下列是操作全步骤

目录

一、操作逻辑

完全命令行方式操作太过麻烦,则新的操作流程如下:

  1. 本地安装mysql和达梦数据库
  2. 将linux服务器中原始mysql数据库导出并导入到本地
  3. 在本地将mysql迁移为达梦
  4. 导出本地达梦数据库内容
  5. 使用命令行导入到linux服务器的达梦数据库中

二、操作步骤

1、本地安装达梦相关工具

本地安装达梦数据库后,会自动安装连接工具。

电脑左下角搜索"DM管理工具"即为达梦数据库连接工具

进入达梦安装目录,tool文件夹中,dts.exe就是迁移工具

如果本地没有安装达梦,也可以下载下面的安装包安装

安装包地址点击链接

2、将服务器mysql导出到本地

a) 服务器命令行导出mysql数据

进入服务器,直接运行下列命令。

将mysql原始数据库hospital_files导出到服务器的/data/目录下,sql文件名为"数据库.sql"

mysqldump --routines -u root -p hospital_files > /data/数据库.sql;

执行完后,会在服务器的/data/目录下生成sql文件,将文件拉取到本地

b) 本地创建mysql库和达梦数据库

先创建hospital_files空数据库,再右键 - 运行sql文件,弹框中文件选取刚才导出的"数据库.sql"文件

本地达梦数据库创建名为"hospital_files"的空数据库

3、本地mysql迁移为达梦

迁移前,本地达梦数据库需要创建与mysql数据库名一样的模式,

我这里mysql数据库名为"hospital_files",所以创建的名为"HOSPITAL_FILES"的模式

打开迁移工具dts.exe - 新建工程 - 新建迁移

新建完成出现如图页面 - 点击下一步

选择mysql → DM选项,点击下一步

输入mysql连接方式 - 点击下一步

注意:如果连接成功,会跳转到下一个页面,否则会报错

输入达梦数据库连接方式 - 点击下一步

注意:如果连接成功,会跳转到下一个页面,否则会报错

这个直接点击下一步

选择对应的数据库 - 点击下一步

点击"反选"即可全选所有的表 - 点击"转换"按钮

将图片上红框的两个打上勾 - 点击确定 - 下一步 - 点击完成

最后会完成迁移工作,如果有报错会有详细提示

迁移完后查看达梦数据库,就有表数据了

4、导出本地达梦数据库

方法一:命令行方式(推荐)

java 复制代码
# 命令解释
./dexp 用户名/密码:端口 file=文件名.dmp directory=/文件输出目录 SCHEMAS=模式名
# 命令实例
./dexp sysdba/'"XXXX@2024"':5236 file=testDM.dmp directory=/opt SCHEMAS=HOSPITAL_FILES

方法二:图形化界面方式

此方式容易出现导入时版本不一致而不能解析的问题

选择对应模式,右键 - 导出 - 弹框中选择导出目录 - 点击确认

5、部署服务器的达梦数据库

a) 修改服务器达梦数据库配置

打开dm.ini文件,位置在dmdbms/data/YLDA文件夹中

修改如下的几个参数

COMPATIBLE_MODE = 4
GROUP_OPT_FLAG = 1
MY_STRICT_TABLES = 1

b) 重启达梦数据库

我的数据库安装在/data/文件夹中

# 进入目录
cd /data/dmdbms/bin
# 停止服务
./DmServiceDAMENG stop
# 开始服务
./DmServiceDAMENG start

c) 导入数据

三、异常处理

1、导入达梦时报错:Error Code:-70028,创建SOCKET连接失败

原因:可能是由于密码符号的问题导致的

方法一:更换达梦数据库密码,不能有特殊字符,比如@

方法二:将密码加上双引号,比如密码为XXXX@2024,语句中改为' " XXXX@2024 " '

java 复制代码
./dimp sysdba/'"XXXX@2024"':5236 file=testDM.dmp directory=/opt SCHEMAS=HOSPITAL_FILES

2、导入达梦时报错:[警告]该工具不能解析此文件,请使用更高版本的工具

原因:导出与导入的版本不一致

方法:使用命令行方式导出

java 复制代码
# 先导出本地达梦数据
./dexp sysdba/'"XXXX@2024"':5236 file=testDM.dmp directory=/opt SCHEMAS=HOSPITAL_FILES

# 再服务器导入达梦数据
./dimp  sysdba/'"XXXX@2024"':5236 directory=/opt file=testDM.dmp SCHEMAS=HOSPITAL_FILES
相关推荐
wowocpp4 分钟前
ubuntu 18 虚拟机安装(1)
mysql
番茄炒西红柿炒蛋5 分钟前
秋招Java后端开发冲刺——非关系型数据库篇(Redis)
数据库·redis·nosql
u01040583625 分钟前
正则表达式数字匹配技巧与应用场景分析
java·mysql·正则表达式
modelsetget29 分钟前
MySQL锁机制详细笔记
数据库·mysql·面试·数据库锁
人才程序员36 分钟前
【Rust入门】生成随机数
开发语言·数据库·后端·单片机·rust
小森( ﹡ˆoˆ﹡ )42 分钟前
【neo4j图数据库】入门实践篇
数据库·人工智能·机器学习·nlp·neo4j
天蓝蓝的本我1 小时前
SQL Server查看所有的数据库、所有的表 以及表的描述
数据库·sqlserver
快快小毛毛1 小时前
弹性伸缩高性能计算服务一一黑石裸金属服务器
运维·服务器·网络·数据库·安全
武帝为此1 小时前
【Spring Boot AOP通知顺序】
java·数据库·spring boot
DaGod1231 小时前
set_source_files_properties QT_QML_SINGLETON_TYPE
数据库