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

达梦数据库迁移j脚本

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

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

备份脚本

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

  • backup_one_db.sh
#!/bin/bashexport 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.sqlecho 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.mrgr.cn/news/74790.html

相关文章:

  • vscode【实用插件】Material Icon Theme 美化文件图标
  • 记录一次Android Studio的下载、安装、配置
  • OpenCV的对比度受限的自适应直方图均衡化算法
  • Linux:动态库和静态库
  • Spring Data Elasticsearch简介
  • CentOS 7.9 通过 yum 安装 Docker
  • C++ STL -- 模版
  • Python 数据可视化pilot
  • 支付宝碰一下系统怎么搭建?方法非常简单!
  • 全球经济风雨飘摇,OJK能带领印尼金融创新走多远?
  • Tcp/Ip协议,tcp相关文章,网络编程,通信协议文章汇总
  • 中国联通将军澳数据中心:全栈解决方案,助力企业创新
  • 51单片机应用开发---LCD1602显示应用
  • 【GPTs】Gif-PT:DALL·E制作创意动图与精灵动画
  • 光伏电站容量计算方法科普
  • 给阿里云OSS绑定域名并启用SSL
  • 深入理解AIGC背后的核心算法:GAN、Transformer与Diffusion Models
  • 【vue】echarts地图添加蒙版图片,多图层地图实现天气信息展示
  • 数字地图的DSM和DOM分别代表什么,它们之间的主要区别是什么?
  • HBase理论_背景特点及数据单元及与Hive对比
  • 【Linux系统编程】第四十六弹---线程同步与生产消费模型深度解析
  • 渗透思路-导学
  • 透视中国电力改革50年
  • A033-停车场管理系统的设计与实现
  • 浪潮M6系列服务器硬件监控指标解读
  • 如何重塑园区管理新生态?