VC++操作SQLite簡單實例
對于很多程序員來說,SQLite并不陌生。SQLite 是一款主要用于嵌入式的開源數(shù)據(jù)庫,可集成在自己的桌面程序中,也可替代Access作為后臺數(shù)據(jù)庫。SQLite 支持多數(shù)SQL92標準,例如:索引、限制、觸發(fā)和查看支持,支持 NULL、INTEGER、REAL、TEXT 和 BLOB 數(shù)據(jù)類型,支持事務。以下是一些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" //請以你的地址為準 #pragma comment(lib, "../sqlite3_lib/sqlite3.lib")//請以你的地址為準 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; }
您可能感興趣的文章
- 01-10深入理解鏈表的各類操作詳解
- 01-10用C語言實現(xiàn)單鏈表的各種操作(一)
- 01-10用C語言實現(xiàn)單鏈表的各種操作(二)
- 01-10深入遍歷二叉樹的各種操作詳解(非遞歸遍歷)
- 01-10C語言字符串操作總結(jié)大全(超詳細)
- 01-10深入C++中構(gòu)造函數(shù)、拷貝構(gòu)造函數(shù)、賦值操作符、析構(gòu)函數(shù)的調(diào)
- 01-10C++輸入輸出操作符重載的深入分析
- 01-10C語言文件操作函數(shù)大全(超詳細)
- 01-10C語言小程序 數(shù)組操作示例代碼
- 01-10解析linux 文件和目錄操作的相關(guān)函數(shù)


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10C#中split用法實例總結(jié)
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 04-02jquery與jsp,用jquery
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置