VC++操作SQLite簡(jiǎn)單實(shí)例
對(duì)于很多程序員來說,SQLite并不陌生。SQLite 是一款主要用于嵌入式的開源數(shù)據(jù)庫,可集成在自己的桌面程序中,也可替代Access作為后臺(tái)數(shù)據(jù)庫。SQLite 支持多數(shù)SQL92標(biāo)準(zhǔn),例如:索引、限制、觸發(fā)和查看支持,支持 NULL、INTEGER、REAL、TEXT 和 BLOB 數(shù)據(jù)類型,支持事務(wù)。以下是一些SQLite的簡(jiǎn)單使用。
//建立數(shù)據(jù)庫 C:\sqlite-3_6_11> sqlite3.exe dbname.db
建立數(shù)據(jù)庫的時(shí)候sqlite3.exe后面跟數(shù)據(jù)庫文件名
//創(chuàng)建數(shù)據(jù)表 sqlite> create table users(userid varchar(20) PRIMARY KEY, ...> age int, ...> birthday datetime); //添加記錄 insert into users values('wang',20,'1989-5-4'); insert into users values('li',22,'1987-11-16'); //查詢記錄 select * from users order by birthday; //刪除記錄 delete from users where userid='wang'; //退出 sqlitesqlite> .exit
SQLite數(shù)據(jù)庫的數(shù)據(jù)結(jié)構(gòu)是存貯在 "sqlite_master" 表中,具體命令可以輸入.help查看或參考SQLite幫助文檔。
在VC下使用SQLite的簡(jiǎn)單例子:
#include "../sqlite3_lib/sqlite3.h" //請(qǐng)以你的地址為準(zhǔn) #pragma comment(lib, "../sqlite3_lib/sqlite3.lib")//請(qǐng)以你的地址為準(zhǔn) static int _sql_callback(void * notused, int argc, char ** argv, char ** szColName) { int i; for ( i=0; i < argc; i++ ) { printf( "%s = %s\n", szColName[i], argv[i] == 0 ? "NUL" : argv[i] ); } return 0; } int main(int argc, char * argv[]) { const char * sSQL1 = "create table users(userid varchar(20) PRIMARY KEY, age int, birthday datetime);"; const char * sSQL2 = "insert into users values('wang',20,'1989-5-4');"; const char * sSQL3 = "select * from users;"; sqlite3 * db = 0; char * pErrMsg = 0; int ret = 0; //連接數(shù)據(jù)庫 ret = sqlite3_open("./test.db", &db); if ( ret != SQLITE_OK ) { fprintf(stderr, "不能打開數(shù)據(jù)庫: %s", sqlite3_errmsg(db)); return(1); } printf("數(shù)據(jù)庫連接成功!\n"); //執(zhí)行SQL建立數(shù)據(jù)庫 sqlite3_exec( db, sSQL1, 0, 0, &pErrMsg ); if ( ret != SQLITE_OK ) { fprintf(stderr, "SQL error: %s\n", pErrMsg); sqlite3_free(pErrMsg); } //插入記錄 sqlite3_exec( db, sSQL2, 0, 0, &pErrMsg); //查詢數(shù)據(jù)表 sqlite3_exec( db, sSQL3, _sql_callback, 0, &pErrMsg); //關(guān)閉數(shù)據(jù)庫 sqlite3_close(db); db = 0; return 0; }
相關(guān)文章
VC實(shí)現(xiàn)的病毒專殺工具完整實(shí)例
這篇文章主要介紹了VC實(shí)現(xiàn)的病毒專殺工具完整實(shí)例,詳細(xì)講述了針對(duì)病毒的進(jìn)程終止、刪除文件及回復(fù)注冊(cè)表與啟動(dòng)項(xiàng)等,同時(shí)介紹了與之相關(guān)的系統(tǒng)函數(shù),非常具有參考借鑒價(jià)值,需要的朋友可以參考下2014-10-10C++實(shí)現(xiàn)折半插入排序(BinaryInsertSort)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)折半插入排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04從匯編看c++的默認(rèn)析構(gòu)函數(shù)的使用詳解
本篇文章是對(duì)c++中默認(rèn)析構(gòu)函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹。需要的朋友參考下2013-05-05C語言實(shí)現(xiàn)將彩色bmp圖像轉(zhuǎn)化為灰圖、灰度圖像反色
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)將彩色bmp圖像轉(zhuǎn)化為灰圖、灰度圖像反色,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10Qt+FFMPEG實(shí)現(xiàn)循環(huán)解碼詳解
這篇文章主要為大家詳細(xì)介紹了如何利用Qt+FFMPEG實(shí)現(xiàn)循環(huán)解碼功能,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Qt有一定幫助,需要的可以參考一下2022-08-08