文章目錄
- 0 背景
- 1 編譯過程
- 2 福利
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"
修改下面兩個文件
/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_TYPECONFIG(static, static|shared)|prefix_build {
# mod_work_pfx = $$MODULE_QMAKE_OUTDIR/mkspecs/modulesmod_work_pfx = /Users/mac/Qt5.15/5.15.2/Src/qtbase/mkspecs/modulesforce_independent: \
# mod_inst_pfx = $$MODULE_QMAKE_OUTDIR/mkspecs/modules-inst
2,添加mysql的外部關聯庫;
mac如下:
macx: LIBS += -L$$PWD/../../../../../../../../../../usr/local/Cellar/mysql@5.7/5.7.44_1/lib/ -lmysqlclient.20INCLUDEPATH += $$PWD/../../../../../../../../../../usr/local/Cellar/mysql@5.7/5.7.44_1/include/mysqlDEPENDPATH += $$PWD/../../../../../../../../../../usr/local/Cellar/mysql@5.7/5.7.44_1/include/mysql
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();}
2 福利
編譯好的mysql驅動,含windows和mac版本的(5.14.2,5.15.2,6.5.3),鏈接如下:
鏈接:https://pan.baidu.com/s/1m15DbFuFTtXfEyqyOS2cew
提取碼: 2o2s