C#数据库备份与恢复mysql

1.利用调用dos窗口进行数据库备份

2.   备份命令: string command = $"mysqldump -u {user} -p{password}  -h {server} -P{port} {database} -R --default-character-set=utf8   > \"{url}{datatime}.sql\"";

working=数据库安装路径,mysqldump所在路径

 private static void StartCommand(string working, string command)
        {
            Process proc = new Process();

            //调用dos窗口
            if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
            {
                proc.StartInfo.FileName = "cmd.exe";
            }
            else
            {
                proc.StartInfo.FileName = "/bin/bash";
            }


            //不显示窗体
            proc.StartInfo.CreateNoWindow = true;
            //设置dos窗口的目录路径,这里就是自己安装mysql的bin目录(我们的mysqldump.exe和mysql.exe所在目录)
            proc.StartInfo.WorkingDirectory = working;
            //允许输入流
            proc.StartInfo.UseShellExecute = false;
            proc.StartInfo.RedirectStandardInput = true;
            proc.StartInfo.RedirectStandardOutput = true;
            proc.StartInfo.RedirectStandardError = true;
            //执行
            proc.Start();

            proc.StandardInput.WriteLine(command);
            proc.WaitForExit(2000);
            //proc.Close();
            proc.StandardInput.WriteLine("exit");
        }

3.数据库恢复

 string create = "create database " + arr[0] + ";";

arr[0]=mysql 安装目录;

url=备份文件所在路径;

   private static void StartRestore(string Working, string url, string user, string password, string[] arr, string create)
        {
            //创建进程对象
            Process proc = new Process();
            //调用dos窗口
            proc.StartInfo.FileName = "cmd.exe";
            //不显示窗体
            proc.StartInfo.CreateNoWindow = true;
            //设置dos窗口的目录路径,这里就是自己安装mysql的bin目录
            proc.StartInfo.WorkingDirectory = Working;

            //允许输入流
            proc.StartInfo.UseShellExecute = false;
            proc.StartInfo.RedirectStandardInput = true;
            proc.StartInfo.RedirectStandardOutput = true;
            proc.StartInfo.RedirectStandardError = true;
            //执行
            proc.Start();
            proc.StandardInput.WriteLine("mysql -u" + user + " -p" + password);
            proc.StandardInput.WriteLine(create);
            proc.StandardInput.WriteLine("use " + arr[0] + ";");
            proc.StandardInput.WriteLine("source  " + url);
            proc.WaitForExit(10000);
            proc.Close();
        }

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值