怎么迁移mysql数据库中的表
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,本篇内容介绍了"怎么迁移mysql数据库中的表"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!作为写脚
千家信息网最后更新 2025年11月07日怎么迁移mysql数据库中的表
本篇内容介绍了"怎么迁移mysql数据库中的表"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
作为写脚本的,这次的重点在于实现了类似于其他语言的logging模块的输出功能。感觉还是蛮有用的,简单直观。
输出log如下所示:
2017-03-31 16:26:57 --- INFO --- You choose the name of the table below:2017-03-31 16:26:57 --- INFO --- 2016_06_24_record_base_log2017-03-31 16:26:57 --- INFO --- 2016_06_16_record_base_log2017-03-31 16:26:57 --- INFO --- table insert statements 2016_06_24_record_base_log backuping2017-03-31 16:26:57 --- INFO --- table struct 2016_06_24_record_base_log backuping2017-03-31 16:26:57 --- INFO --- table insert statements 2016_06_16_record_base_log backuping2017-03-31 16:26:57 --- INFO --- table struct 2016_06_16_record_base_log backuping2017-03-31 16:26:57 --- INFO --- append the ENGINE=InnoDB --> DATA DIRECTORY\=\'\/data2\/db\/mysql\'/ to struct/2016_06_24_record_base_log.sql2017-03-31 16:26:57 --- INFO --- append the ENGINE=InnoDB --> DATA DIRECTORY\=\'\/data2\/db\/mysql\'/ to struct/2016_06_16_record_base_log.sql2017-03-31 16:26:57 --- INFO --- There is no back up the table2017-03-31 16:26:57 --- INFO --- The import table structure2017-03-31 16:26:57 --- INFO --- Insert data to the table2017-03-31 16:26:57 --- INFO --- There is no back up the table2017-03-31 16:26:57 --- INFO --- The import table structure2017-03-31 16:26:57 --- INFO --- Insert data to the table2017-03-31 16:26:57 --- INFO --- Successfully completed the operation !
shell脚本如下所示,此脚本在centos系统测试通过:
#!/bin/bashmysqluser='root'mysqlpass='dbpassword'mysqlhost='127.0.0.1'mysqldb='dbname'mysqlpath='/usr/local/mysql/bin'mysqlport=3306datetimes=`date "+%Y-%m-%d %H:%M:%S"`datetimes2=`date "+%Y%m%d%H%M"`datetimes3=`date "+%Y%m%d%H%M%S"`backupdir="backup"structdir="struct"logfile="logs/test_${datetimes3}.log"tablist="ltab.txt"# Set the echo colorgray='\033[30;1m'red='\033[31;1m'green='\033[32;1m'yellow='\033[33;1m'blue='\033[34;1m'pink='\033[35;1m'white='\033[37;1m'reset='\033[0m'[ ! -d $backupdir ] && mkdir -p $backupdir[ ! -d $structdir ] && mkdir $structdir[ ! -d logs ] && mkdir logs# logging functionfunction logging { if [ ! -z "$1" ] && [ ! -z "$2" ];then echo -e "${green} ${1} --- ${2} ${reset}" echo -e "${datetimes} --- ${1} --- ${2}" >> $logfile fi}function error { if [ $? -eq 0 ];then logging "INFO" "$1" else logging "ERROR" "${reset}${red} $1 ,have an error occurred!" exit 1 fi}function yesorno { echo -e "${yellow} $1 ${reset}" read var case "$var" in [yY][eE][sS] ) echo "Your input is YES,Program to continue" ;; [nN][oO] ) echo "Your input is no."; exit 0;; **) echo -e "${red} Input Error! ${reset}" exit 0 ;; esac}echo -e "${yellow} This script is used to mysql table DATA DIRECTORY and INDEX DIRECTORY set to/data2/db/mysql and the migration of data to /data2/db/mysql directory. ${reset} " yesorno "Do you want to continue, yes or no?"logging "INFO" "You choose the name of the table below:"# Confirm the table to by updatefor tab in `cat $tablist`;do logging "INFO" "${tab}"doneyesorno "The above is the table you choose, you want to continue? Yes or no?"# dump table data and struct to $backupdir and $structdirfor tab in `cat $tablist`;do $mysqlpath/mysqldump -u$mysqluser -p$mysqlpass -h$mysqlhost -P$mysqlport --no-create-info $mysqldb $tab > ${backupdir}/${tab}.sql error "table insert statements $tab backuping" $mysqlpath/mysqldump -u$mysqluser -p$mysqlpass -h$mysqlhost -P$mysqlport --no-data $mysqldb $tab > ${structdir}/${tab}.sql error "table struct $tab backuping"done# append the DATA DIRECTOY and DATA DIRINDEX to table struct.for tab in `cat $tablist`;do if grep 'ENGINE=InnoDB' ${structdir}/${tab}.sql;then sed -i "s/ENGINE=InnoDB/& DATA DIRECTORY\=\'\/data2\/db\/mysql\' INDEX DIRECTORY\=\'\/data2\/db\/mysql\'/" ${structdir}/${tab}.sql error "append the ENGINE=InnoDB --> DATA DIRECTORY\=\'\/data2\/db\/mysql\'/ to ${structdir}/${tab}.sql" elif grep 'ENGINE=MyISAM' ${structdir}/${tab}.sql;then sed -i "s/ENGINE=MyISAM/& DATA DIRECTORY\=\'\/data2\/db\/mysql\' INDEX DIRECTORY\=\'\/data2\/db\/mysql\'/" ${structdir}/${tab}.sql error "append the ENGINE=InnoDB --> DATA DIRECTORY\=\'\/data2\/db\/mysql\'/ to ${structdir}/${tab}.sql" else logging "ERROR,Table structure is not found in the match engine ." exit 1 fidone# drop old database for tab in `cat $tablist`;do if [ -f ${backupdir}/${tab}.sql ] && [ -f ${structdir}/${tab}.sql ];then $mysqlpath/mysql -u$mysqluser -p$mysqlpass -h$mysqlhost -P$mysqlport $mysqldb -e "drop table ${tab};" error "There is no back up the table" fi # import table struct to db if [ -f ${structdir}/${tab}.sql ];then $mysqlpath/mysql -u$mysqluser -p$mysqlpass -h$mysqlhost -P$mysqlport $mysqldb < ${structdir}/${tab}.sql error "The import table structure" fi # import table data to db if [ -f ${backupdir}/${tab}.sql ];then $mysqlpath/mysql -u$mysqluser -p$mysqlpass -h$mysqlhost -P$mysqlport $mysqldb < ${backupdir}/${tab}.sql error "Insert data to the table" fidonelogging "INFO" "Successfully completed the operation !"ltab.txt中存储你要想迁移的表名,如下所示:
[root@SERVER_DB] cat ltab.txt2016_06_24_record_base_log2016_06_16_record_base_log
最后,记得在screen下执行脚本,即使终端断开,也不用担心,脚本终止执行。如果遇到错误,脚本会立即终止执行,此时需要手动来处理。
"怎么迁移mysql数据库中的表"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
脚本
输出
数据
数据库
内容
更多
知识
实用
直观
学有所成
接下来
不用
功能
困境
实际
情况
感觉
手动
文章
有用
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
浙江常见软件开发成交价
摩尔庄园338服务器
软件开发课程与教学
华为高级软件开发工资待遇
cs1.6服务器延迟高怎么办
吉林软件开发研发公司
数据库理论与技术论文
如何连接db2数据库
下载服务器搭建教程视频
河南省威海软件开发
全国网络安全空间所以学校
网络安全 与 保密的关系
网络安全飞行试验
数据库汇总报表怎么做
第三方抢票软件开发
用tnt跑酷的服务器
临沂智慧社区软件开发哪儿好
linux服务器开端口
万方数据库高级检索入口
一个www服务器通常被称为
海不眠html源码对接数据库
进入服务器系统
win7数据库2000
绵阳市览众网络技术有限公司
数据库原理教改项目中期报告
查外文文章数据库有哪些
网信办网络安全周宣传
网络安全教案信息技术
个人征信信息基础数据库管理办法
网络安全防火墙属于什么专业