QT裡使用sqlite的問題,好多坑

來源:互聯網
上載者:User

標籤:

1. 我使用sqlite,開發機上好好的,測試機上卻不行。後來發現是缺少驅動(Driver not loaded Driver not loaded),代碼檢查了又檢查,發現應該是缺少dll檔案(系統不提示,是自己使用 QMessageBox::warning(NULL, ("error"), database.lastError().text());後猜到的)。於是自己千方百計的想辦法,反覆測試,就是不行。結果悲劇的發現,原來是多次設定路徑錯誤,浪費一上午時間。應該直接在可執行exe檔案的同一目錄下設定目錄和檔案如下即可:
my.exe\sqldrivers\qsqlite4.dll
既不要寫成:
my.exe\plugins\sqldrivers\qsqlite4.dll
也不要寫成
my.exe\sqldrivers\sqlite\qsqlite4.dll (因為QT自己的目錄就是C:\Qt\4.8.6_2008\src\plugins\sqldrivers\sqlite)
另外,放在my.exe同一目錄下也沒有用。

2. 編程的時候,注意不能使用new QSqlDatabase();後調用addDatabase()函數。原因是什麼我也不知道,反正結論在這裡:
http://qt-project.org/doc/qt-4.8/qsqldatabase.html#open

3. 編程的時候注意,要填上QSQLITE,不是SQLITE
QSqlDatabase database = QSqlDatabase::addDatabase("QSQLITE");

4. 使用QSqlDatabase::addDatabase函數的時候,如果是一個臨時對象,那麼要把它命名一下,比如(關鍵是第二個參數):
QSqlDatabase localdb = QSqlDatabase::addDatabase("QSQLITE", "Old_DB");
如果不寫這第二個參數,那麼就會把這個新串連當作預設串連,這樣申請QSqlQuery對象但不寫明資料庫連接的話就會出錯。

5. 使用 QSqlDatabase::removeDatabase的時候,必須把前面所有語句括弧括起來,莫名其妙的一種用法。不過既然是官方文檔這樣說,就記住它,遵守它,相關連結在這裡:
http://qt-project.org/doc/qt-4.8/qsqldatabase.html#removeDatabase

6. 還有一個檔案qsqlited4.dll,不知道是幹什麼。

7. 可以很方便的使用VS編譯C:\Qt\4.8.6_2008\src\plugins\sqldrivers\sqlite路徑下的sqlite.pro工程檔案,Release編譯後得到一個dll,放在相關的路徑裡使用沒有問題。

8. Process Explorer這個軟體可以清楚地顯示,當前開發exe檔案依賴哪些DLL,很有協助。這樣就不用動腦筋了,觀察結果即可。比如它我對這個項目提示依賴:

C:\Qt\4.8.6_2008\plugins\sqldrivers\qsqlite4.dll
但是注意,它提示的是開發機上的dll路徑,客戶機上的路徑不一定是這樣的。

但它的提示也只能作為一種參考,不能完全當真,它還提示我使用:
C:\Qt\4.8.6_2008\plugins\imageformats\qtiff4.dll
可是我根本就沒有使用tiff檔案。所以這個提示作為一種參考,找到自己需要的資訊即可。

總結,QT發布版的坑真是多,怪不得QT公司不讓免費使用者靜態編譯和修改,大概是只讓高手們用它來玩的。不知道靜態編譯是否可以避免這些問題。

---------------------------------------------------------------------------

幾個有用串連:
http://qt-project.org/doc/qt-4.8/sql-driver.html
http://blog.sina.com.cn/s/blog_a6fb6cc90101gx30.html
http://blog.csdn.net/hustyangju/article/details/17799189
http://blog.chinaunix.net/uid-28394603-id-3775493.html (討論復原)

安裝MySQL驅動:
http://blog.sina.com.cn/s/blog_74a7e56e01017s64.html

外掛程式工作機制:
http://blog.csdn.net/dbzhang800/article/details/6543489
http://blog.csdn.net/csfreebird/article/details/17793161

SQLite學習手冊
http://my.oschina.net/eechen/blog/84641
http://my.oschina.net/eechen/blog/84639
http://www.oschina.net/question/12_53183 (一個小時內學習 SQLite 資料庫)

 

QT裡使用sqlite的問題,好多坑

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.