一步一步實現C++操作SQLite資料庫

來源:互聯網
上載者:User

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:ix86

     問題一: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:示範代碼

       主要的原始碼來自網上,這個是我修改過的。

  1. #include <iostream>   
  2. using namespace std;  
  3. #include "./sqlite/sqlite3.h"   
  4. #pragma comment(lib, "./sqlite/sqlite3.lib")   
  5. static int _callback_exec(void * notused,int argc, char ** argv, char ** aszColName)  
  6. {  
  7.     int i;  
  8.     for ( i=0; i<argc; i++ )  
  9.     {  
  10.         printf( "%s = %s\n", aszColName[i], argv[i] == 0 ? "NUL" : argv[i] );  
  11.     }  
  12.     return 0;  
  13. }  
  14. int main(int argc,char * argv[])  
  15. {  
  16.     const char * file ="test.db";  
  17.     const char * sSQL = "select * from stu;";  
  18.     char * pErrMsg = 0;  
  19.     int ret = 0;  
  20.     sqlite3 * db = 0;  
  21.     ret = sqlite3_open("./test.db", &db);  
  22.     if ( ret != SQLITE_OK )  
  23.     {  
  24.         fprintf(stderr, "Could not open database: %s", sqlite3_errmsg(db));  
  25.         exit(1);  
  26.     }  
  27.     printf("Successfully connected to database\n");  
  28.     sqlite3_exec( db, sSQL, _callback_exec, 0, &pErrMsg );  
  29.     if ( ret != SQLITE_OK )  
  30.     {  
  31.         fprintf(stderr, "SQL error: %s\n", pErrMsg);  
  32.         sqlite3_free(pErrMsg);  
  33.     }  
  34.   
  35.     sqlite3_close(db);  
  36.     db = 0;  
  37.   
  38.     return 0;  
  39. }  

4:SQLite使用小問題說明

        我在命令列操作SQLite資料庫時,進入後一直不能產生一個資料庫,並且產生表的命令也不成功。

       後來終於明白了,SQLite命令列的形式為:sqlite.exe  dbfile,後面的即為資料庫名,如果不存在,在操作後會自動產生一個資料庫名。

        SQLite的SQL命令都是以“;”為結束符,開始一直執行不成功,原來是沒有加入“;”語句結束符號。

        終於完成了一個簡單的操作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.