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

达梦数据库迁移j脚本

国产环境使用达梦数据库的越来越多,除了使用管理工具,还是可以使用脚本。

下面简单记录下,我在迁移中遇到的问题:

备份脚本

使用此脚本可以一次备份一个数据

  • backup_one_db.sh
#!/bin/bash

export DB=$1
export PASS=<your_password>
export DB_IP=<your_ip>
export DB_PORT=5236
export BACKUP_DIR=/data/backup
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/dameng/bin

/home/dameng/bin/dexp USERID=SYSDBA/\"$PASS\"@$DB_IP:$DB_PORT FILE=$DB.dmp LOG=$DB.log SCHEMAS=$DB DIRECTORY=$BACKUP_DIR

运行示例:

$ backup_one_db.sh TEST_DB
# ...

$ ls /data/backup
TEST_DB.dmp TEST_DB.log

恢复脚本

  • restore_one_db.sh
#!/bin/bash
# source database name
export SOURCE_DB=$1
# target database name
export TARGET_DB=$2
# target database password
export TARGET_DB_PASS=<replace_your_password>
# target database ip
export TARGET_DB_IP=<your_ip>
export TARGET_DB_PORT=5432

# SYSDBA password
export SYSDBA_PASS=<replace_your_password>
# backup data dir path
export RESTORE_DATADIR=/data/restore/backup
# 将达梦DLL加入动态链接库
export LIBRARY_PATH=$LIBRARY_PATH:/home/dameng/bin
# dameng bin目录
export DAMENG_BIN_PATH=/home/dameng/bin


# create target database  

tmp_sql_file=$RESTORE_DATADIR/create_db_tmp.sql

echo CREATE USER \"$TARGET_DB\" IDENTIFIED BY \"$TARGET_DB_PASS\" HASH WITH SHA512 NO SALT PASSWORD_POLICY 2 ENCRYPT BY \"$TARGET_DB_PASS\" > $tmp_sql_file
echo LIMIT FAILED_LOGIN_ATTEMPS 3, PASSWORD_LOCK_TIME 1, PASSWORD_GRACE_TIME 10 DEFAULT TABLESPACE \"MAIN\" \; >> $tmp_sql_file
echo grant DBA  to \"$TARGET_DB\" \; >> $tmp_sql_file
echo "exit" >> $tmp_sql_file

# execute create db sql
# 必须在sql文件前加: \`
$DAMENG_BIN_PATH/disql USERID=SYSDBA/\"$SYSDBA_PASS\"@$TARGET_DB_IP:$TARGET_DB_PORT \`$tmp_sql_file

# import data to target database
$DAMENG_BIN_PATH/dimp USERID=$TARGET_DB/\"$TARGET_DB_PASS\"@$TARGET_DB_IP:$TARGET_DB_PORT FILE=$RESTORE_DATADIR/$SOURCE_DB.dmp LOG=$SOURCE_DB.log SCHEMAS=$SOURCE_DB DIRECTORY=$RESTORE_DATADIR REMAP_SCHEMA=$SOURCE_DB:$TARGET_DB

用法:要输入两个参数,第一个参数为源数据库,第二个参数为目的数据库。如果你迁库前,数据库名都是一样,写一样就行。

bash restore_one_db.sh $SOURCE_DB $TARGET_DB

创建表空间

create tablespace "ONE_TEST_DB" datafile '/data/DAMENG/ONE_TEST_DB.DBF' size 128 ;

一些情况下会遇见,数据库创建不用MAIN表空间的问题,以上SQL会创建一个表空间。


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

相关文章:

  • vue3【实战】切换全屏【组件封装】FullScreen.vue
  • 第八节 如何结合AAA实现用户远程登录-路由基础
  • Tiktok对接和内容发布申请流程
  • Day 65 || SPFA、判断负权回路、bellman_ford之单源有限最短路
  • 解决背景图因为图片路径中携带括号导致图片无法显示的问题
  • Easyui ComboBox 数据加载完成之后过滤数据
  • 24 年第十届数维杯国际数模竞赛赛题浅析
  • 【启明智显分享】5G CPE为什么适合应用在连锁店中?
  • 信捷PLC转以太网连接电脑方法
  • Dart:字符串
  • centos7 安装rabbitMQ3.7.15
  • HarmonyOS Next星河版笔记--界面开发(5)
  • 微信小程序之轮播图
  • 这个 AI 懂 Vue 吗?
  • YOLOv5、YOLOv6、YOLOv7、YOLOv8、YOLOv9、YOLOv10、YOLOv11 推理的 C++ 和 Python 实现
  • g++与gdb简单学习
  • git常用命令+搭vscode使用
  • 【云岚到家】-day10-2-冷热处理及统计
  • mp4文件与dash流传输
  • 5. langgraph中的react agent使用 (从零构建一个react agent)
  • 2个word内容合并
  • Go语言24小时极速学习教程(四)MySQL数据库的增删改查
  • 求矩阵中最小元素及其位置
  • 区块链安全性解析:Web3的去信任化与技术挑战
  • SpringBoot多环境+docker集成企业微信会话存档sdk
  • Android 最新的AndroidStudio引入依赖失败如何解决?如:Failed to resolve:xxxx