標籤:
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的問題,好多坑