1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        一步一步實現C++操作SQLite數據庫

        發布時間:  2012/8/26 16:02:22

        SQLite,是一款輕型的數據庫,是遵守ACID的關聯式關系數據庫,目前已經在很多嵌入式產品中使用了它,它占用資源非常的低,在嵌入式設備中,可能只需要幾百K的內存就夠了。它能夠支持Windows/Linux/Unix等等主流的操作系統,同樣的代碼可以實現跨平臺編譯,這個數據庫和微軟的Access很象,都是小型的數據庫管理系統,最大的差別為sqlite不需要office的支持,可以完全開源,是真正意義上的跨平臺的數據庫。
        由于工作的需要,這幾天對sqlite數據庫研究一下,并使用C++對其進行了簡單的操作。中間遇到了很多問題,找到了很多資料終于解決了?偨Y問題,不管提高,所以把遇到的問題和解決辦法寫出來,希望對大家有用。

        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文件?墒窃次募挥衧qlite3.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的程序。
         


        本文出自:億恩科技【www.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          0
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线