Linux(Ubuntu 19.10)下 Qt5 連接 MySQL(QMYSQL driver not loaded)

Linux(Ubuntu 19.10)下 Qt5 連接 MySQL

  1. 安裝好 MySQL 和 Qt

  2. Qt 連接 MySQL 的代碼

    QSqlDatabase d=QSqlDatabase::addDatabase("QMYSQL");//加載mysql驅動,這個字符串是固定的
    d.setHostName("127.0.0.1");
    d.setDatabaseName("mysql");        //數據庫名稱
    d.setPort(3306);                     //數據庫端口,如果沒有更改/etc/mysql/my.cnf就不用改
    d.setUserName("root");
    d.setPassword("123467");
    if(d.open())qDebug()<<"數據庫連接成功";
    elseqDebug()<<"數據庫連接失敗";
    

    運行后發現報錯:

    QSqlDatabase: QMYSQL driver not loaded
    QSqlDatabase: available drivers: QSQLITE QODBC QODBC3 QPSQL QPSQL7
    

    原因是沒有 MySQL驅動 或 MySQL 驅動版本不對,驅動放在/home/junebao/Qt/5.14.2/gcc_64/plugins/sqldrivers:

    有兩個文件:

    1. libqsqlmysql.so.debug
    2. libqsqlmysql.so

    這兩個文件不存在或版本與 Qt 版本不匹配都會導致上面的錯誤

解決 QMYSQL driver not loaded

官方文檔:

UTOOLS1590741069581.png

  1. ~/Qt/5.14.2/Src/qtbase/src/plugins/sqldrivers 目錄下 執行 qmake -- MYSQL_PREFIX=/usr/local

    • ~/Qt/5.14.2是 Qt 的下載目錄

    • usr/local是 MySQL 的安裝目錄

    • 如果出現qtbase/src/plugins/sqldrivers/sqldrivers.pro:16: Unknown test function: qtConfig 是因為默認鏈接的 qmake可能是 Qt4 的,可以使用 Qt5 qmake 的完整路徑執行:~/Qt/5.14.2/gcc_64/bin/qmake -- MYSQL_PREFIX=/usr/local

  2. 執行 make sub-mysql

    • make 的過程中可能會缺依賴,缺啥下啥就好了
  3. 執行完后在~/Qt/5.14.2/Src/qtbase/plugins/sqldrivers目錄(和上面不是同一個目錄)下會出現libqsqlmysql.so.debuglibqsqlmysql.so兩個文件

    • 如果這一步沒有生成那兩個文件,回到第一步試著執行~/Qt/Qt5.14.2/5.11.2/gcc_64/bin/qmake "INCLUDEPATH+=/usr/include/mysql" "LIBS+=-L/usr/lib/x86_64-linux-gnu/ -lmysqlclient" mysql.pro
  4. 把他們復制到/home/junebao/Qt/5.14.2/gcc_64/plugins/sqldrivers下面就好了

環境

  • OS:Ubuntu 19.10.1(64位)
  • Qt: 5.14.2
  • MySQL: 8.0.20

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/457442.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/457442.shtml
英文地址,請注明出處:http://en.pswp.cn/news/457442.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

華為消息推送 有透傳通道嗎_求解在推送用透傳消息-使用廠商通道(我用的是基座測試) 用手機測試出現了“clientId離線”問題...

// #ifdef APP-PLUS// uni.showModal({// title: 提示,// content: 您的用戶在其它的app登錄&#xff0c;如果有問題&#xff0c;請修改密碼或重新登錄&#xff01;,// cancelText:"修改密碼",// confirmText:"好的",// success: function (res) {// if (r…

oneuijs/You-Dont-Need-jQuery

oneuijs/You-Dont-Need-jQuery https://github.com/oneuijs/You-Dont-Need-jQuery/blob/master/README.zh-CN.mdYou Dont Need jQuery 前端發展很快&#xff0c;現代瀏覽器原生 API 已經足夠好用。我們并不需要為了操作 DOM、Event 等再學習一下 jQuery 的 API。同時由于 React…

Wpf 數據綁定簡介、實例1

簡介&#xff1a;1.WPF綁定使用的源屬性必須是依賴項屬性&#xff0c;這是因為依賴項屬性具有內置的更改通知支持&#xff0c;元素綁定表達式使用了Xaml擴展標記&#xff0c; WPF綁定一個控件是使用Binding.ElementName, 綁定非控件對象時使用Source,RelativeSource,DataContex…

【設計模式 04】代理模式

代理模式 代理模式( Proxy)&#xff1a;為其他對象提供一種代理以控制對這個對象的訪問。 參考&#xff1a;refactoringguru | proxy 什么是代理模式 有時候如果想要訪問某個對象&#xff0c;但又沒辦法直接訪問或不方便直接訪問&#xff0c;可以使用代理模式&#xff0c;代理…

css 大于號 標簽_CSS設計基礎選擇器篇

點擊上方 Java項目學習 &#xff0c;選擇 星標 公眾號重磅資訊、干貨&#xff0c;第一時間送達前言&#xff1a;如果將CSS樣式應用于特定的網頁對象上&#xff0c;需要先找到目標元素。在CSS樣式中執行這一任務的部分被稱為選擇器。1 標簽選擇器優點&#xff1a;為頁面中同類型…

CSDN博客投票活動開始了

自己堅持寫博客&#xff0c;一方面是為了將自己對知識點的理解做一個總結&#xff0c;另一方面也是因為自己看到了很多無私奉獻分享自己知識的小伙伴們&#xff0c;因此自己也想像他們那樣盡自己微薄之力把自己對某一知識點的理解分享給大家&#xff0c;或許算不上什么特高級的…

crontab 提示 command not found 解決方案

crontab 提示 command not found 解決方案 今天遇見一個問題&#xff0c;crontab的定時任務會報錯&#xff1a;java command not found&#xff0c;但是手動執行腳本一直能成功。 猜想是環境變量的問題。 在crontab里添加個打印環境變量的任務&#xff1a; * * * * * echo $PAT…

java中文亂碼decode_Java中文亂碼處理

java編碼轉換過程我們總是用一個java類文件和用戶進行最直接的交互(輸入、輸出)&#xff0c;這些交互內容包含的文字可能會包含中文。無論這些java類是與數據庫交互&#xff0c;還是與前端頁面交互&#xff0c;他們的生命周期總是這樣的&#xff1a;1、程序員在操作系統上通過編…

【設計模式 05】工廠方法模式

工廠方法模式 define an interface or abstract class for creating an object but let the subclasses decide which class to instantiate. 參考&#xff1a; refactoringguru | factory-methodjavatpoint | factory-method-design-pattern博客園| 工廠方法 簡單工廠的問題 …

[C++]宏定義#define A B C

C關于宏定義的用法&#xff0c;有形如#define A B C的格式&#xff0c;此時B和C都是已知的字符串常量. 在宏定義中. 可以把兩個常量字符串連在一起 如果#define A "a" 那么宏定義#define STRING A "bc" 就相當于 #define STRING "abc" 這里&…

LinkedList類源碼淺析(二)

1、上一節介紹了LinkedList的幾個基本的方法&#xff0c;其他方法類似&#xff0c;就不一一介紹&#xff1b; 現在再來看一個刪除的方法&#xff1a;remove(Object o) remove方法接受一個Object參數&#xff0c;這里需要對參數做空與非空處理&#xff1b; 但是刪除一個Object元…

【設計模式 06】原型模式(克隆??)

原型模式(clone?) Prototype pattern refers to creating duplicate object while keeping performance in mind. This type of design pattern comes under creational pattern as this pattern provides one of the best ways to create an object. 參考&#xff1a; tutori…

2016OSC源創會年終盛典-綜合技術專場-張小剛

2019獨角獸企業重金招聘Python工程師標準>>> 綜合技術專場 講師/SPEAKERS 張小剛 網易云負載均衡項目負責人 《網易蜂巢負載均衡技術實踐》從網易蜂巢中的實踐出發&#xff0c;分享網易蜂巢負載均衡服務從無到有&#xff0c;從私有云到公有云過程中的技術實踐。重點…

python策略模式包含角色_詳解Python設計模式之策略模式

雖然設計模式與語言無關&#xff0c;但這并不意味著每一個模式都能在每一門語言中使用。《設計模式&#xff1a;可復用面向對象軟件的基礎》一書中有 23 個模式&#xff0c;其中有 16 個在動態語言中“不見了&#xff0c;或者簡化了”。1、策略模式概述策略模式&#xff1a;定義…

mysql 日期

數據類型 數據類型格式date YYYY-MM-DD datetime YYYY-MM-DD HH:MM:SS timestamp YYYY-MM-DD HH:MM:SS year YYYY 或 YY 具體實現的函數 1、now() 返回當前的日期和時間 SELECT NOW(); 2、curdate() 返回當前的日期 SELECT CURdate(); 3、curtime&#xff08;&#xff09;返回當…

【Go】panic: reflect: call of reflect.Value.FieldByName on ptr Value

產生原因 調用 FieldByName()方法時&#xff0c;調用者與預期類型不相符。 // 錯誤代碼 func setNewArticleInfoToCache(article *Article) {fields : []string{"Title", "Abstract", "ID", "AuthorID", "CreateTime",}im…

超完整的 Chrome 瀏覽器客戶端調試大全

2019獨角獸企業重金招聘Python工程師標準>>> 引言 “工欲善其事&#xff0c;必先利其器” 沒錯&#xff0c;這句話個人覺得說的特別有道理&#xff0c;舉個例子來說吧&#xff0c;厲害的化妝師都有一套非常專業的刷子&#xff0c;散粉刷負責定妝&#xff0c;眼影刷負…

PHP 獲取服務器詳細信息【轉】

碰到此問題&#xff0c;做下記錄 獲取系統類型及版本號&#xff1a; php_uname() (例&#xff1a;Windows NT COMPUTER 5.1 build 2600)只獲取系統類型&#xff1a; php_uname(s) (或&#xff1…

HIVE攻略 JFK_Hive安裝及使用攻略

目錄Hive的安裝Hive的基本使用:CRUDHive交互式模式數據導入數據導出Hive查詢HiveQLHive視圖Hive分區表1. Hive的安裝系統環境裝好hadoop的環境后&#xff0c;我們可以把Hive裝在namenode機器上(c1)。hadoop的環境&#xff0c;請參考&#xff1a;讓Hadoop跑在云端系列文章&#…

MySQL 為什么用索引,為什么是 B+樹,怎么用索引

MySQL 索引 A database index is a data structure that improves the speed of operations in a table. Indexes can be created using one or more columns, providing the basis for both rapid random lookups and efficient ordering of access to records. 為什么需要索…