如何解决使用QProcess调用mysql CLI命令
因此,我试图从主应用程序外部在命令行中编写各种命令。在这种情况下,将在MysqL中创建数据库表。
到目前为止,这是我当前的实现方式:
QString program = "cmd.exe"; // Using command line
QStringList arguments;
arguments <<"/c" << "cd" << "C:\\Program Files\\MariaDB 10.4\\bin" ; // Completes first command
QProcess *myProcess = new QProcess();
myProcess->setWorkingDirectory("C:\\WINDOWS\\system32");
myProcess->start(program,arguments);
myProcess->waitForStarted(-1);
qDebug("Passed Started");
int test = myProcess->state();
qDebug() <<"State: "<< myProcess->state();
myProcess->write("MysqL -u root -p \n");
myProcess->waitForReadyRead();
myProcess->write("password \n");
myProcess->waitForReadyRead();
myProcess->write("CREATE DATABASE database; \n");
myProcess->waitForReadyRead();
qDebug () << " Ok " << myProcess->readAllStandardOutput() << myProcess->readAllStandardError();
myProcess->waitForFinished(-1);
运行此命令时,不会创建任何数据库,但是当我将命令行参数写入命令行本身时,它将起作用。我在QProcess的实现方面缺少什么?我怎么知道我正在写的每一行是否都被命令行等接受?
更新1: 我将参数更改为:
arguments <<"/k" << "C:\Program Files\MariaDB 10.4\bin\MysqL.exe" << "--defaults-file=C:\Program Files\MariaDB 10.4\data\my.ini -u root -p";
但是仍然存在无法完成数据库创建的问题。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。