亚洲综合社区欧美综合色-欧美逼逼一区二区三区-国产老熟女高潮精品网站-国产日韩最新视频在线看

始創(chuàng)于2000年 股票代碼:831685
咨詢(xún)熱線:0371-60135900 注冊(cè)有禮 登錄
  • 掛牌上市企業(yè)
  • 60秒人工響應(yīng)
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補(bǔ)償
全部產(chǎn)品
您的位置: 網(wǎng)站首頁(yè) > 幫助中心>文章內(nèi)容

一步一步實(shí)現(xiàn)C++操作SQLite數(shù)據(jù)庫(kù)

發(fā)布時(shí)間:  2012/8/26 16:02:22

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

1:下載源碼并編譯

       我下的版本為sqlite-amalgamation-3070701.zip,這個(gè)包含了主要的源代碼。sqlite-dll-win32-x86-3070701.zip這個(gè)是Windows下的編譯好的DLL文件和def文件,解壓縮后包含兩個(gè)文件,sqlite3.def和sqlite3.dll。

       編譯源代碼很簡(jiǎn)單,新建立一個(gè)C++空項(xiàng)目,把sqlite-amalgamation-3070701.zip解壓縮后的文件拷進(jìn)去,編譯、鏈接,就行了。

我的目的是把sqlite數(shù)據(jù)庫(kù)作為自己項(xiàng)目中的一部分,是作為嵌入的一部分使用的。這個(gè)要利用到sqlite3.dll文件。可是源文件只有sqlite3.def和sqlite3.dll沒(méi)有sqlite3.lib文件,怎么用呢?

        LIB文件和DLL文件其實(shí)是差不多的,只是使用的時(shí)間不同。LIB文件使用在編譯階段DLL文件使用在運(yùn)行階段。根據(jù)def文件可以生成對(duì)應(yīng)的LIB文件。以下是命令行生成LIB文件。

      找到VS的安裝路徑,我的是D:\Program Files\,用命令行進(jìn)入以下路徑。

      D:\Program Files\Microsoft Visual Studio 9.0\VC\bin>lib /def:sqlite3.def /machine:ix86

     問(wèn)題一:mspdb80.dll無(wú)法找到

       原因是當(dāng)前路徑下沒(méi)有“msobj80.dll,mspdb80.dll,mspdbcore.dll,mspdbsrv.exe”這四個(gè)文件。

      解決辦法:Common7\IDE\下復(fù)制這四個(gè)文件到VC\Bin\下即可解決。

     對(duì)應(yīng)生成lib文件需要注意的是把sqlite3.def拷到上述路徑下,使用命令行生成后會(huì)產(chǎn)生sqlite3.lib文件,這個(gè)就是在程序中編譯時(shí)需要的文件。顯示的結(jié)果為:

Microsoft (R) Library Manager Version 9.00.21022.08

Copyright (C) Microsoft Corporation.  All rights reserved.

正在創(chuàng)建庫(kù) sqlite3.lib 和對(duì)象 sqlite3.exp

2:在C++中操作SQLite數(shù)據(jù)庫(kù)

         問(wèn)題二:沒(méi)有找到sqlite3.dll,因此這個(gè)應(yīng)用程序未能啟動(dòng)

         我在我把sqlite3.dll,sqlite3.h,sqlite3.lib拷到同一個(gè)文件夾里,編譯時(shí)已知出現(xiàn)這個(gè)問(wèn)題。

原來(lái)是程序執(zhí)行時(shí)需要的DLL按照當(dāng)前工作路徑、系統(tǒng)目錄的順序搜索DLL文件。我的DLL文件沒(méi)有和可執(zhí)行文件在同一個(gè)路徑下,肯定要出錯(cuò)了。明白這些,把sqlite3.dll拷到Debug文件夾下,問(wèn)題解決了。

3:演示代碼

       主要的源代碼來(lái)自網(wǎng)上,這個(gè)是我修改過(guò)的。

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使用小問(wèn)題說(shuō)明

        我在命令行操作SQLite數(shù)據(jù)庫(kù)時(shí),進(jìn)入后一直不能生成一個(gè)數(shù)據(jù)庫(kù),并且生成表的命令也不成功。

       后來(lái)終于明白了,SQLite命令行的形式為:sqlite.exe  dbfile,后面的即為數(shù)據(jù)庫(kù)名,如果不存在,在操作后會(huì)自動(dòng)生成一個(gè)數(shù)據(jù)庫(kù)名。

        SQLite的SQL命令都是以“;”為結(jié)束符,開(kāi)始一直執(zhí)行不成功,原來(lái)是沒(méi)有加入“;”語(yǔ)句結(jié)束符號(hào)。

        終于完成了一個(gè)簡(jiǎn)單的操作SQLite的程序。
 


本文出自:億恩科技【1tcdy.com】

服務(wù)器租用/服務(wù)器托管中國(guó)五強(qiáng)!虛擬主機(jī)域名注冊(cè)頂級(jí)提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經(jīng)營(yíng)性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經(jīng)營(yíng)性ICP/ISP/IDC證:豫B1.B2-20060070
  • 億恩南昌公司:
  • 經(jīng)營(yíng)性ICP/ISP證:贛B2-20080012
  • 服務(wù)器/云主機(jī) 24小時(shí)售后服務(wù)電話:0371-60135900
  • 虛擬主機(jī)/智能建站 24小時(shí)售后服務(wù)電話:0371-60135900
  • 專(zhuān)注服務(wù)器托管17年
    掃掃關(guān)注-微信公眾號(hào)
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權(quán)所有  地址:鄭州市高新區(qū)翠竹街1號(hào)總部企業(yè)基地億恩大廈  法律顧問(wèn):河南亞太人律師事務(wù)所郝建鋒、杜慧月律師   京公網(wǎng)安備41019702002023號(hào)
      0
     
     
     
     

    0371-60135900
    7*24小時(shí)客服服務(wù)熱線