当前位置:   article > 正文

编译qt5.15.2(mac/windows)的mysql驱动(附带编译好的文件)_pri: cannot create parent directory

pri: cannot create parent directory

0 背景

因为需要连接到mysql数据库,所以需要连mysql驱动。

在这里插入图片描述

1 编译过程

1,打开文件/Users/mac/Qt5.14.2/5.14.2/Src/qtbase/src/plugins/sqldrivers/sqldrivers.pro,注释掉QMAKE_USE += mysql
请添加图片描述
如果出现如下错误(Cannot read /qtsqldrivers-config.pri: No such file or directory):

Info: creating stash file /Users/fjl/Qt/5.15.2/Src/qtbase/src/plugins/sqldrivers/.qmake.stash
Cannot read /qtsqldrivers-config.pri: No such file or directory
/Users/fjl/Qt/5.15.2/clang_64/mkspecs/features/qt_plugin.prf:59: Cannot write file /mkspecs/modules-inst/qt_plugin_qsqlmysql.pri: Cannot create parent directory
09:46:44: 进程"/Users/fjl/Qt/5.15.2/clang_64/bin/qmake"退出,退出代码 3 。
Error while building/deploying project mysql (kit: Desktop Qt 5.15.2 clang 64bit)
When executing step "qmake"
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

修改下面两个文件
/Users/mac/Qt5.15/5.15.2/clang_64/mkspecs/features/qt_plugin.prf
/Users/mac/Qt5.15/5.15.2/Src/qtbase/mkspecs/features/qt_plugin.prf,修改方法相同,把注释的内容修改为下面一行的内容(注意路径替换为自己的本地路径):

# DESTDIR = $$MODULE_BASE_OUTDIR/plugins/$$PLUGIN_TYPE
DESTDIR = /Users/mac/Qt5.15/5.15.2/Src/qtbase/plugins/$$PLUGIN_TYPE

CONFIG(static, static|shared)|prefix_build {
#    mod_work_pfx = $$MODULE_QMAKE_OUTDIR/mkspecs/modules
    mod_work_pfx = /Users/mac/Qt5.15/5.15.2/Src/qtbase/mkspecs/modules
    force_independent: \
#       mod_inst_pfx = $$MODULE_QMAKE_OUTDIR/mkspecs/modules-inst
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

2,添加mysql的外部关联库;

请添加图片描述

请添加图片描述

请添加图片描述
mac如下:

macx: LIBS += -L$$PWD/../../../../../../../../../../usr/local/Cellar/mysql@5.7/5.7.44_1/lib/ -lmysqlclient.20

INCLUDEPATH += $$PWD/../../../../../../../../../../usr/local/Cellar/mysql@5.7/5.7.44_1/include/mysql

DEPENDPATH += $$PWD/../../../../../../../../../../usr/local/Cellar/mysql@5.7/5.7.44_1/include/mysql
  • 1
  • 2
  • 3
  • 4
  • 5

3,编译文件,得到mysql驱动

请添加图片描述

4,把编译好的mysql放入到如下文件夹sqldrivers中,把mysql的库文件也放入到bin

请添加图片描述

请添加图片描述

5,运行测试程序。

#include "mainwindow.h"

#include <QApplication>
#include <QSqlDatabase>
#include <QDebug>


int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    
    // MainWindow w;
    // w.show();

    qDebug()<<"查看目前可用驱动";
    QStringList drivers = QSqlDatabase::drivers();
    for(auto driver: drivers){
        qDebug()<<driver<<" ";
    }

    //设置数据库驱动
    QSqlDatabase db1 = QSqlDatabase::addDatabase("QMYSQL", "connection1");
    db1.setHostName("192.168.0.104");
    db1.setUserName("root");
    db1.setPassword("password");
    db1.setPort(3309);
    db1.setDatabaseName("test_db");

    if(db1.open()){
        qDebug()<<"数据库打开成功";
    }

    return a.exec();


}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37

2 福利

编译好的mysql驱动,含windows和mac版本的(5.14.2,5.15.2,6.5.3),链接如下:

链接:https://pan.baidu.com/s/1m15DbFuFTtXfEyqyOS2cew
提取码: 2o2s

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/641600
推荐阅读
相关标签
  

闽ICP备14008679号