一步一步實現(xiàn)C++操作SQLite數(shù)據(jù)庫 |
發(fā)布時間: 2012/8/26 16:02:22 |
SQLite,是一款輕型的數(shù)據(jù)庫,是遵守ACID的關(guān)聯(lián)式關(guān)系數(shù)據(jù)庫,目前已經(jīng)在很多嵌入式產(chǎn)品中使用了它,它占用資源非常的低,在嵌入式設(shè)備中,可能只需要幾百K的內(nèi)存就夠了。它能夠支持Windows/Linux/Unix等等主流的操作系統(tǒng),同樣的代碼可以實現(xiàn)跨平臺編譯,這個數(shù)據(jù)庫和微軟的Access很象,都是小型的數(shù)據(jù)庫管理系統(tǒng),最大的差別為sqlite不需要office的支持,可以完全開源,是真正意義上的跨平臺的數(shù)據(jù)庫。 1:下載源碼并編譯 我下的版本為sqlite-amalgamation-3070701.zip,這個包含了主要的源代碼。sqlite-dll-win32-x86-3070701.zip這個是Windows下的編譯好的DLL文件和def文件,解壓縮后包含兩個文件,sqlite3.def和sqlite3.dll。 編譯源代碼很簡單,新建立一個C++空項目,把sqlite-amalgamation-3070701.zip解壓縮后的文件拷進(jìn)去,編譯、鏈接,就行了。 我的目的是把sqlite數(shù)據(jù)庫作為自己項目中的一部分,是作為嵌入的一部分使用的。這個要利用到sqlite3.dll文件。可是源文件只有sqlite3.def和sqlite3.dll沒有sqlite3.lib文件,怎么用呢? LIB文件和DLL文件其實是差不多的,只是使用的時間不同。LIB文件使用在編譯階段DLL文件使用在運(yùn)行階段。根據(jù)def文件可以生成對應(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 問題一:mspdb80.dll無法找到 原因是當(dāng)前路徑下沒有“msobj80.dll,mspdb80.dll,mspdbcore.dll,mspdbsrv.exe”這四個文件。 解決辦法:Common7\IDE\下復(fù)制這四個文件到VC\Bin\下即可解決。 對應(yīng)生成lib文件需要注意的是把sqlite3.def拷到上述路徑下,使用命令行生成后會產(chǎn)生sqlite3.lib文件,這個就是在程序中編譯時需要的文件。顯示的結(jié)果為: Microsoft (R) Library Manager Version 9.00.21022.08 Copyright (C) Microsoft Corporation. All rights reserved. 正在創(chuàng)建庫 sqlite3.lib 和對象 sqlite3.exp 2:在C++中操作SQLite數(shù)據(jù)庫 問題二:沒有找到sqlite3.dll,因此這個應(yīng)用程序未能啟動 我在我把sqlite3.dll,sqlite3.h,sqlite3.lib拷到同一個文件夾里,編譯時已知出現(xiàn)這個問題。 原來是程序執(zhí)行時需要的DLL按照當(dāng)前工作路徑、系統(tǒng)目錄的順序搜索DLL文件。我的DLL文件沒有和可執(zhí)行文件在同一個路徑下,肯定要出錯了。明白這些,把sqlite3.dll拷到Debug文件夾下,問題解決了。 3:演示代碼 主要的源代碼來自網(wǎng)上,這個是我修改過的。 1.#include <iostream> 4:SQLite使用小問題說明 我在命令行操作SQLite數(shù)據(jù)庫時,進(jìn)入后一直不能生成一個數(shù)據(jù)庫,并且生成表的命令也不成功。 后來終于明白了,SQLite命令行的形式為:sqlite.exe dbfile,后面的即為數(shù)據(jù)庫名,如果不存在,在操作后會自動生成一個數(shù)據(jù)庫名。 SQLite的SQL命令都是以“;”為結(jié)束符,開始一直執(zhí)行不成功,原來是沒有加入“;”語句結(jié)束符號。 終于完成了一個簡單的操作SQLite的程序。 本文出自:億恩科技【mszdt.com】 服務(wù)器租用/服務(wù)器托管中國五強(qiáng)!虛擬主機(jī)域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM] |