微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用QProcess调用mysql CLI命令

如何解决使用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 举报,一经查实,本站将立刻删除。