SQLite,是一款輕型的數據庫,是遵守ACID的關聯式關係數據庫,目前已經在很多嵌入式產品中使用了它,它佔用資源非常的低,在嵌入式設備中,可能只需要幾百K的內存就夠了。它能夠支持Windows/Linux/Unix等等主流的操作系統,同樣的代碼可以實現跨平臺編譯,這個數據庫和微軟的Access很象,都是小型的數據庫管理系統,最大的差別爲sqlite不需要office的支持,可以完全開源,是真正意義上的跨平臺的數據庫。
由於工作的需要,這幾天對sqlite數據庫研究一下,並使用C++對其進行了簡單的操作。中間遇到了很多問題,找到了很多資料終於解決了。總結問題,不管提高,所以把遇到的問題和解決辦法寫出來,希望對大家有用。
1:下載源碼並編譯
我下的版本爲sqlite-amalgamation-3070701.zip,這個包含了主要的源代碼。sqlite-dll-win32-x86-3070701.zip這個是Windows下的編譯好的DLL文件和def文件,解壓縮後包含兩個文件,sqlite3.def和sqlite3.dll。
編譯源代碼很簡單,新建立一個C++空項目,把sqlite-amalgamation-3070701.zip解壓縮後的文件拷進去,編譯、鏈接,就行了。
我的目的是把sqlite數據庫作爲自己項目中的一部分,是作爲嵌入的一部分使用的。這個要利用到sqlite3.dll文件。可是源文件只有sqlite3.def和sqlite3.dll沒有sqlite3.lib文件,怎麼用呢?
LIB文件和DLL文件其實是差不多的,只是使用的時間不同。LIB文件使用在編譯階段DLL文件使用在運行階段。根據def文件可以生成對應的LIB文件。以下是命令行生成LIB文件。
找到VS的安裝路徑,我的是D:\Program Files\,用命令行進入以下路徑。
D:\Program Files\Microsoft Visual Studio 9.0\VC\bin>lib /def:sqlite3.def /machine:x86
問題一:mspdb80.dll無法找到
原因是當前路徑下沒有“msobj80.dll,mspdb80.dll,mspdbcore.dll,mspdbsrv.exe”這四個文件。
解決辦法:Common7\IDE\下複製這四個文件到VC\Bin\下即可解決。
對應生成lib文件需要注意的是把sqlite3.def拷到上述路徑下,使用命令行生成後會產生sqlite3.lib文件,這個就是在程序中編譯時需要的文件。顯示的結果爲:
Microsoft (R) Library Manager Version 9.00.21022.08
Copyright (C) Microsoft Corporation. All rights reserved.
正在創建庫 sqlite3.lib 和對象 sqlite3.exp
2:在C++中操作SQLite數據庫
問題二:沒有找到sqlite3.dll,因此這個應用程序未能啓動
我在我把sqlite3.dll,sqlite3.h,sqlite3.lib拷到同一個文件夾裏,編譯時已知出現這個問題。
原來是程序執行時需要的DLL按照當前工作路徑、系統目錄的順序搜索DLL文件。我的DLL文件沒有和可執行文件在同一個路徑下,肯定要出錯了。明白這些,把sqlite3.dll拷到Debug文件夾下,問題解決了。
3:演示代碼
主要的源代碼來自網上,這個是我修改過的。
- #include <iostream>
- using namespace std;
- #include "./sqlite/sqlite3.h"
- #pragma comment(lib, "./sqlite/sqlite3.lib")
- static int _callback_exec(void * notused,int argc, char ** argv, char ** aszColName)
- {
- int i;
- for ( i=0; i<argc; i++ )
- {
- printf( "%s = %s\n", aszColName[i], argv[i] == 0 ? "NUL" : argv[i] );
- }
- return 0;
- }
- int main(int argc,char * argv[])
- {
- const char * file ="test.db";
- const char * sSQL = "select * from stu;";
- char * pErrMsg = 0;
- int ret = 0;
- sqlite3 * db = 0;
- ret = sqlite3_open("./test.db", &db);
- if ( ret != SQLITE_OK )
- {
- fprintf(stderr, "Could not open database: %s", sqlite3_errmsg(db));
- exit(1);
- }
- printf("Successfully connected to database\n");
- sqlite3_exec( db, sSQL, _callback_exec, 0, &pErrMsg );
- if ( ret != SQLITE_OK )
- {
- fprintf(stderr, "SQL error: %s\n", pErrMsg);
- sqlite3_free(pErrMsg);
- }
- sqlite3_close(db);
- db = 0;
- return 0;
- }
4:SQLite使用小問題說明
我在命令行操作SQLite數據庫時,進入後一直不能生成一個數據庫,並且生成表的命令也不成功。
後來終於明白了,SQLite命令行的形式爲:sqlite.exe dbfile,後面的即爲數據庫名,如果不存在,在操作後會自動生成一個數據庫名。
SQLite的SQL命令都是以“;”爲結束符,開始一直執行不成功,原來是沒有加入“;”語句結束符號。