VC++操作SQLite簡單實例
對于很多程序員來說,SQLite并不陌生。SQLite 是一款主要用于嵌入式的開源數(shù)據(jù)庫,可集成在自己的桌面程序中,也可替代Access作為后臺數(shù)據(jù)庫。SQLite 支持多數(shù)SQL92標(biāo)準(zhǔn),例如:索引、限制、觸發(fā)和查看支持,支持 NULL、INTEGER、REAL、TEXT 和 BLOB 數(shù)據(jù)類型,支持事務(wù)。以下是一些SQLite的簡單使用。
//建立數(shù)據(jù)庫 C:\sqlite-3_6_11> sqlite3.exe dbname.db
建立數(shù)據(jù)庫的時候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的簡單例子:
#include "../sqlite3_lib/sqlite3.h" //請以你的地址為準(zhǔn) #pragma comment(lib, "../sqlite3_lib/sqlite3.lib")//請以你的地址為準(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)文章
C++實現(xiàn)折半插入排序(BinaryInsertSort)
這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)折半插入排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-04-04從匯編看c++的默認(rèn)析構(gòu)函數(shù)的使用詳解
本篇文章是對c++中默認(rèn)析構(gòu)函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹。需要的朋友參考下2013-05-05C語言實現(xiàn)將彩色bmp圖像轉(zhuǎn)化為灰圖、灰度圖像反色
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)將彩色bmp圖像轉(zhuǎn)化為灰圖、灰度圖像反色,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10