国产精品久久久久久久久久久新郎_91久久精品国产_国内精品久久久久久_欧美激情第一页在线观看_国产欧美日韩丝袜精品一区_日韩精品成人一区二区在线观看_国产精品v片在线观看不卡_91精品国产综合久久香蕉最新版 _国产精品亚洲激情_色综合男人天堂

始創于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++對其進行了簡單的操作。中間遇到了很多問題,找到了很多資料終于解決了。總結問題,不管提高,所以把遇到的問題和解決辦法寫出來,希望對大家有用。

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的程序。
 


本文出自:億恩科技【m.czbl888.cn】

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

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

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

     
     
    国产精品久久久久久久久久久新郎_91久久精品国产_国内精品久久久久久_欧美激情第一页在线观看_国产欧美日韩丝袜精品一区_日韩精品成人一区二区在线观看_国产精品v片在线观看不卡_91精品国产综合久久香蕉最新版 _国产精品亚洲激情_色综合男人天堂
    男人女人黄一级| 亚洲自偷自拍熟女另类| 成人免费a级片| 涩涩网站在线看| 亚洲精品高清无码视频| 国产自产在线视频| 欧美日韩dvd| 亚洲高清视频免费| 国产区二区三区| 成人免费xxxxx在线视频| 97国产在线播放| 国产综合中文字幕| 伊人再见免费在线观看高清版 | 乱子伦一区二区| 国产探花在线看| 手机免费看av网站| 亚洲精品www.| 国产欧美一区二| 国产精品自在自线| 亚洲最新免费视频| 久久久成人精品一区二区三区| 国产精品久久久久久久av福利| 日韩av在线中文| 国内外成人免费在线视频| 一路向西2在线观看| 五月婷婷之综合激情| 欧美性大战久久久久xxx| 九一国产精品视频| 欧美日韩第二页| 亚洲 欧美 日韩系列| 99国产精品久久久久久| 天天做天天爱天天高潮| www.激情网| 欧美久久久久久久久久久久久 | 欧美亚洲黄色片| 少妇无码av无码专区在线观看| 日韩国产欧美亚洲| 国产一级不卡毛片| 五月天视频在线观看| 福利网在线观看| 色婷婷成人在线| 亚洲国产高清av| 久久av秘一区二区三区| 嫩草影院中文字幕| 国产免费观看高清视频| 男女av免费观看| 成年人三级黄色片| 老司机激情视频| 黄色国产精品视频| 色男人天堂av| 精品视频免费在线播放| 奇米影音第四色| 免费看黄色a级片| 黄色a级片免费| 成年人黄色在线观看| 老太脱裤子让老头玩xxxxx| 国产情侣av自拍| 欧美一级小视频| 无码av天堂一区二区三区| 国产三级日本三级在线播放| 日本特级黄色大片| 国产精品-区区久久久狼| 91蝌蚪视频在线| 国产精品秘入口18禁麻豆免会员| www.com污| koreanbj精品视频一区| 一级淫片在线观看| 浮妇高潮喷白浆视频| 男人午夜视频在线观看| 黄色一级在线视频| 波多野结衣与黑人| 国产精品国产亚洲精品看不卡| 国产又大又黄又粗的视频| 少妇一晚三次一区二区三区| 男人舔女人下面高潮视频| 中文字幕黄色大片| 激情视频综合网| www.亚洲成人网| 污污动漫在线观看| 国产 日韩 欧美在线| 午夜激情视频网| 欧美国产激情视频| 精品视频在线观看一区二区| 邪恶网站在线观看| 成人黄色大片网站| 天美一区二区三区| 一起操在线视频| 日本wwwcom| 国产亚洲精品久久久久久久| 国产成人手机视频| 老司机午夜免费福利视频| 污污视频网站免费观看| 91视频 - 88av| 三区视频在线观看| 日本熟妇人妻xxxxx| 日韩在线观看a| 欧美国产日韩在线视频| 激情综合网俺也去| 国产69精品久久久久久久| 一级全黄肉体裸体全过程| 日韩在线第三页| jizzjizz国产精品喷水| 996这里只有精品| 香蕉视频xxx| 在线观看免费的av| 日本熟妇人妻xxxxx| 奇米影视亚洲色图| 蜜臀精品一区二区| 欧美日韩午夜爽爽| 97超碰免费观看| 日本中文字幕影院| 久久国产精品国产精品| 国产精品免费成人| 国产精品无码专区av在线播放| 黄色一级片播放| 国产黄视频在线| 成人毛片一区二区| 男女猛烈激情xx00免费视频| avav在线播放| 国产视频在线观看网站| 一二三四中文字幕| 在线观看免费黄色片| 特黄特黄一级片| www.色.com| 中文字幕第22页| 欧美精品 - 色网| 99日在线视频| 91视频福利网| 激情图片qvod| 国产精品久久久久久久久电影网| 一级性生活视频| 男人天堂a在线| 阿v天堂2018| 免费一级特黄特色毛片久久看| 很污的网站在线观看| 很污的网站在线观看| 日韩精品―中文字幕| 黄在线观看网站| 国产自偷自偷免费一区| 九九九在线观看视频| www午夜视频| 五月天男人天堂| 99久久久精品视频| 日本少妇高潮喷水视频| 日本老熟妇毛茸茸| 一路向西2在线观看| 色网站在线视频| 青青视频免费在线| av动漫在线看| 成人亚洲精品777777大片| 国产aⅴ爽av久久久久| 热这里只有精品| 成人黄色av片| 三级在线免费看| 亚洲va在线va天堂va偷拍| 熟妇熟女乱妇乱女网站| 国产精品久久久久久久乖乖| 国产主播在线看| 91亚洲精品久久久蜜桃借种| 欧美在线观看黄| 无码人妻丰满熟妇区毛片18| 高潮一区二区三区| 久久亚洲a v| 最近免费中文字幕中文高清百度| 蜜桃福利午夜精品一区| 成年人网站国产| 青春草在线视频免费观看| 青青青国产在线视频| 亚洲不卡视频在线| 老司机av福利| 无码中文字幕色专区| www.夜夜爽| 成人小视频在线观看免费| 午夜精品久久久久久久无码| 一本色道久久亚洲综合精品蜜桃 | 激情伊人五月天| 粉色视频免费看| 欧洲精品在线播放| 亚洲国产高清av| 久久亚洲国产成人精品无码区| 亚洲中文字幕久久精品无码喷水| 日韩欧美色视频| 99精品视频在线看| 久久久久亚洲av无码专区喷水| 黄色免费观看视频网站| 亚洲综合激情五月| 免费裸体美女网站| 黄色一级视频播放| 亚洲一区二区三区四区五区xx| 日本男女交配视频| 日韩av片专区| 爱福利视频一区二区| 超碰在线免费观看97| 亚洲中文字幕久久精品无码喷水| 4444在线观看| 国产色视频在线播放| 欧美成人xxxxx| www.亚洲成人网| 91精品视频国产| 黄色三级视频在线|