C#备份还原MySql数据库

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 原文:C#备份还原MySql数据库      项目结束,粘点代码出来让Google或Baidu一下,原因是现在还搜不到这么现成的       调用MySql的工具mysqldump来实现。       类Cmd来实现调用cmd命令, 要启动的进程所在的目录是说mysql自动的备份还原数据库工具mysqldump和mysql所在目录,当然,这个方法可以执行别的命令行工具。
原文: C#备份还原MySql数据库

      项目结束,粘点代码出来让Google或Baidu一下,原因是现在还搜不到这么现成的

      调用MySql的工具mysqldump来实现。

      类Cmd来实现调用cmd命令,
要启动的进程所在的目录是说mysql自动的备份还原数据库工具mysqldump和mysql所在目录,当然,这个方法可以执行别的命令行工具。

 

using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.Diagnostics;

    
public   class  Cmd
    {
        
///   <summary>
        
///  执行Cmd命令
        
///   </summary>
        
///   <param name="workingDirectory"> 要启动的进程的目录 </param>
        
///   <param name="command"> 要执行的命令 </param>
         public   static   void  StartCmd(String workingDirectory, String command)
        {
            Process p 
=   new  Process();
            p.StartInfo.FileName 
=   " cmd.exe " ;
            p.StartInfo.WorkingDirectory 
=  workingDirectory;
            p.StartInfo.UseShellExecute 
=   false ;
            p.StartInfo.RedirectStandardInput 
=   true ;
            p.StartInfo.RedirectStandardOutput 
=   true ;
            p.StartInfo.RedirectStandardError 
=   true ;
            p.StartInfo.CreateNoWindow 
=   true ;
            p.Start();
            p.StandardInput.WriteLine(command);
            p.StandardInput.WriteLine(
" exit " );
        }
    }

 

备份方法:

using  System;
using  System.Collections.Generic;
using  System.ComponentModel;
using  System.Data;
using  System.Drawing;
using  System.Text;
using  System.Windows.Forms;
using  System.IO;
using  System.Diagnostics;
using  System.Configuration;

using  MDRClient.DataAccess;

namespace  MDRClient
{
    
public   partial   class  DataBackup : Form
    {
        
public  DataBackup()
        {
            InitializeComponent();
        }

        
private   void  btnBackup_Click( object  sender, EventArgs e)
        {
            
try
            {
                
// String command = "mysqldump --quick --host=localhost --default-character-set=gb2312 --lock-tables --verbose  --force --port=端口号 --user=用户名 --password=密码 数据库名 -r 备份到的地址";

                
// 构建执行的命令
                StringBuilder sbcommand  =   new  StringBuilder();

                StringBuilder sbfileName 
=   new  StringBuilder();
                sbfileName.AppendFormat(
" {0} " , DateTime.Now.ToString()).Replace( " - " "" ).Replace( " : " "" ).Replace( "   " "" );
                String fileName 
=  sbfileName.ToString();

                SaveFileDialog saveFileDialog 
=   new  SaveFileDialog();
                saveFileDialog.AddExtension 
=   false ;
                saveFileDialog.CheckFileExists 
=   false ;
                saveFileDialog.CheckPathExists 
=   false ;
                saveFileDialog.FileName 
=  fileName;

                
if  (saveFileDialog.ShowDialog()  ==  DialogResult.OK)
                {
                    String directory 
=  saveFileDialog.FileName;

                    sbcommand.AppendFormat(
" mysqldump --quick --host=localhost --default-character-set=gbk --lock-tables --verbose  --force --port=端口号 --user=用户名 --password=密码 数据库名 -r \ " { 0 }\ "" , directory);
                    String command 
=  sbcommand.ToString();

                    
// 获取mysqldump.exe所在路径
                    String appDirecroty  =  System.Windows.Forms.Application.StartupPath  +   " \\ " ;
                    Cmd.StartCmd(appDirecroty, command);
                    MessageBox.Show(
@" 数据库已成功备份到  "   +  directory  +   "  文件中 " " 提示 " , MessageBoxButtons.OK, MessageBoxIcon.Information);
                }

            }
            
catch  (Exception ex)
            {
                MessageBox.Show(
" 数据库备份失败! " );
                
            }
        }
        
    }
}

 

还原方法,调用的是mysql自带工具mysql,还原时要注意的是选择的文件所在路径时,文件名要是有空格的话会出
异常,所以在文件路径名加上双引号""

using  System;
using  System.Collections.Generic;
using  System.ComponentModel;
using  System.Data;
using  System.Drawing;
using  System.Text;
using  System.Windows.Forms;
using  System.IO;
using  System.Diagnostics;
using  System.Configuration;

using  MDRClient.DataAccess;

namespace  MDRClient
{
    
public   partial   class  DataRestore : Form
    {
        
public  DataRestore()
        {
            InitializeComponent();
        }

        
private   void  btnRestore_Click( object  sender, EventArgs e)
        {

            
// string s = "mysql --port=端口号 --user=用户名 --password=密码 数据库名<还原文件所在路径";

            
try
            {
                StringBuilder sbcommand 
=   new  StringBuilder();

                OpenFileDialog openFileDialog 
=   new  OpenFileDialog();

                
if  (openFileDialog.ShowDialog()  ==  DialogResult.OK)
                {
                    String directory 
=  openFileDialog.FileName;

                    
// 在文件路径后面加上""避免空格出现异常
                    sbcommand.AppendFormat( " mysql --host=localhost --default-character-set=gbk --port=端口号 --user=用户名 --password=密码 数据库<\ " { 0 }\ "" , directory);
                    String command 
=  sbcommand.ToString();

                    
// 获取mysql.exe所在路径
                    String appDirecroty  =  System.Windows.Forms.Application.StartupPath  +   " \\ " ;

                    DialogResult result 
=  MessageBox.Show( " 您是否真的想覆盖以前的数据库吗?那么以前的数据库数据将丢失!!! " " 警告 " , MessageBoxButtons.YesNo, MessageBoxIcon.Warning);
                    
if  (result  ==  DialogResult.Yes)
                    {
                        Cmd.StartCmd(appDirecroty, command);
                        MessageBox.Show(
" 数据库还原成功! " );
                    }
                }
                
            }
            
catch  (Exception ex)
            {
                MessageBox.Show(
" 数据库还原失败! " );
            }

        }
        
    }
}

 

 

 

 

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
4月前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
335 10
|
9月前
|
关系型数据库 MySQL Shell
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
|
10月前
|
存储 关系型数据库 分布式数据库
PolarDB开源数据库进阶课5 在线备份
本文介绍了如何在PolarDB RAC一写多读集群中进行在线备份,特别针对共享存储模式。通过使用`polar_basebackup`工具,可以将实例的本地数据和共享数据备份到本地盘中。实验环境依赖于Docker容器中用loop设备模拟的共享存储。
284 1
|
6月前
|
存储 关系型数据库 MySQL
【赵渝强老师】使用select...into outfile语句备份MySQL
本文介绍了MySQL中使用`SELECT...INTO OUTFILE`语句将表数据导出为文本文件的方法。通过示例演示了如何备份员工表(emp)的数据,包括创建存储目录、设置权限、配置参数`secure_file_priv`以及解决相关错误的过程。字段分隔符和行终止符可自定义,确保数据格式符合需求。最后展示了备份文件的内容,验证操作成功。
410 36
|
6月前
|
存储 SQL 关系型数据库
【赵渝强老师】使用mysqldump备份MySQL
本文介绍了 MySQL 自带的逻辑备份工具 mysqldump 的使用方法。通过 mysqldump,可以将数据库中的数据转换为对应的 SQL 插入语句,便于备份和还原。文章详细说明了如何备份所有数据库、指定数据库及特定表,排除某些表不备份的操作,以及删除数据库后如何通过备份文件恢复数据。同时提供了视频讲解和具体命令示例,帮助用户更好地理解和应用该工具。
260 5
|
6月前
|
存储 SQL 关系型数据库
【赵渝强老师】使用mydumper备份MySQL
本文介绍了使用mydumper工具进行MySQL数据库备份与恢复的操作方法。相比单线程工作的mysqldump,mydumper支持多线程,速度提升可达10倍。其功能包括事务性表快照、快速压缩、导出binlog等,并提供详细的参数说明和操作步骤。文章通过实例演示了安装mydumper、创建存储目录、全库备份、指定数据库及表备份、删除数据库以及使用myloader恢复数据的完整流程,并附带视频讲解,帮助用户更好地理解和应用该工具。
260 0
|
8月前
|
关系型数据库 MySQL Linux
在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾
以上就是在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾的步骤。这个过程就像是一场接力赛,数据从MySQL数据库中接力棒一样传递到备份文件,再从备份文件传递到其他服务器,最后再传递回MySQL数据库。这样,即使在灾难发生时,我们也可以快速恢复数据,保证业务的正常运行。
361 28
|
8月前
|
存储 关系型数据库 MySQL
利用Cron表达式实现MySQL数据库的定时备份
以上就是如何使用Cron表达式和mysqldump命令实现MySQL数据库的定时备份。这种方法的优点是简单易用,而且可以根据需要定制备份的时间和频率。但是,它也有一些限制,例如,它不能备份MySQL服务器的配置文件和用户账户信息,也不能实现增量备份。如果需要更复杂的备份策略,可能需要使用专门的备份工具或服务。
199 15
|
9月前
|
关系型数据库 Shell 网络安全
定期备份数据库:基于 Shell 脚本的自动化方案
本篇文章分享一个简单的 Shell 脚本,用于定期备份 MySQL 数据库,并自动将备份传输到远程服务器,帮助防止数据丢失。
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
722 3

热门文章

最新文章

推荐镜像

更多