在Qt中使用QProcess备份和恢复Mysql数据库

移动开发
在Qt中使用QProcess备份和恢复Mysql数据库是本文要介绍的内容,主要是来了解QT中数据库如何来备份和恢复,具体内容的实现来看本文详解。

使用QtMySQL数据库开发,遇到需要备份、还原数据库的问题。MySQL中没有提供将数据库备份成.sql文件的SQL语句,而是提供了一个mysqldump.exe工具来完成这个功能。没有SQL语句,QSqlQuery就用不成了,决定改用QProcess实现。

但是在Qt中使用QProcess::execute()方法怎样都导不出数据来,更郁闷的是在Qt提供的Qt Command Prompt命令行工具里都提示找不到mysqldump.exe程序,
刚开始我怀疑,莫非Qt就是不支持非Windows/System32目录指令之外的指令了?
.
上网搜索"qt 备份Mysql数据库",结果就发现问题的原因了。这篇"Qt中使用QProcess::execute()时需要注意的问题",在Windows中的Qt程序使用QProcess::execute()方法,不能使用管道、重定向操作符,要有重定向操作符把内容重定向到文件或者从文件中读取输入的话,则需要设置QProcess对象的标准输入、输出文件为自己需要的文件。

一般来说Windows中使用的命令行程序很少有用到管道和重定向的,因为Windows的控制台本身不支持管道和重定向操作。

但这个mysqldump就是个特例,它需要将输出重定向到文件。

但是像

  1. QProcess::execute("mysqldump.exe -uUsrName -pUsrPsd DbName > d:/backup.sql") 

的函数是执行不了的,至少在windows里执行不出来。

从Qt4.2开始QProcess提供了setStandardInputFile (), setStandardOutputFile (),  setStandardOutputProcess (). 三个函数来处理Windows中程序遇到管道和重定向问题,用start()方法替代execute()方法,然后使用 setStandardOutputFile ()等方式重定向输出或输入。

具体就是,应该将mysqldump操作写成下面这样:

  1. QString Cmd = QString("mysqldump.exe --add-drop-table -u%1 -p%2 test").arg("UsrName","UsrPsd");    
  2. QString Path = QString("%1").arg("d://backup.Sql");    
  3. QProcess *poc=new QProcess;    
  4. poc->setStandardOutputFile(Path);    
  5. poc->start(Cmd);    
  6.     QString Cmd = QString("mysqldump.exe --add-drop-table -u%1 -p%2 test").arg("UsrName","UsrPsd");  
  7.     QString Path = QString("%1").arg("d://backup.Sql");  
  8.     QProcess *poc=new QProcess;  
  9.     poc->setStandardOutputFile(Path);  
  10.     poc->start(Cmd); 

相应的还原数据库操作应该写成这样:

  1. QString Cmd = QString("mysql.exe -u%1 -p%2 test").arg("UsrName","UsrPsd");    
  2. QString Path = QString("%1").arg("d://backup.Sql");    
  3. QProcess *poc=new QProcess;    
  4. poc->setStandardInputFile(Path);    
  5. poc->start(Cmd);   

小结:在Qt中使用QProcess备份和恢复Mysql数据库的内容介绍完了,希望通过本文的学习能对你有所帮助!

责任编辑:zhaolei 来源: 互联网
相关推荐

2023-09-21 09:31:24

MySQL数据库

2023-12-07 15:09:23

2011-01-20 10:39:09

postfixmysql

2011-06-28 10:03:37

Qt OpenCV qmake

2010-10-14 09:36:47

MySQL命令行

2010-04-12 10:40:49

Oracle数据库

2019-02-28 21:20:50

MySQL备份与恢复数据库

2010-04-12 14:19:00

Oracle数据库备份

2010-08-09 13:30:27

DB2数据库备份

2011-06-10 10:31:57

QT mysql linux

2010-07-08 11:05:14

SQL Server数

2023-09-12 09:45:54

Java数据库

2010-10-14 10:18:28

MySQL数据库备份

2011-07-05 10:16:16

Qt 数据库 SQLite

2011-04-01 10:40:07

SQL Server数备份恢复

2010-03-30 10:05:02

Oracle数据库

2009-04-03 10:54:49

Oracle备份恢复

2023-12-27 22:08:39

vivo数据库

2009-01-19 09:14:31

.NETMySQLMySql驱动包

2009-06-10 14:42:50

NetBeans IDJava DB数据库
点赞
收藏

51CTO技术栈公众号