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

php中文网
发布: 2016-06-01 13:06:42
原创
2104人浏览过

.

使用Qt做MySQL数据库开发,遇到需要备份、还原数据库的问题。

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()时需要注意的问题"

(原文地址http://www.qtcn.org/blog/article.php?itemid-629-type-blog.html)

写到,在Windows中的Qt程序使用QProcess::execute()方法,不能使用管道、重定向操作符,要有重定向操作符把内容重定向到文件或者从文件中读取输入的话,则需要设置QProcess对象的标准输入、输出文件为自己需要的文件。

.

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

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

但是像QProcess::execute("mysqldump.exe -uUsrName -pUsrPsd DbName > d:/backup.sql")的函数是执行不了的,至少在windows里执行不出来。

.

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

.

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

[cpp] view plaincopy

  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);  
 

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

[cpp] view plaincopy

  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);  
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号