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ù)結構是存貯在 "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);
//關閉數(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語言字符串操作總結大全(超詳細)
- 01-10深入C++中構造函數(shù)、拷貝構造函數(shù)、賦值操作符、析構函數(shù)的調
- 01-10C++輸入輸出操作符重載的深入分析
- 01-10C語言文件操作函數(shù)大全(超詳細)
- 01-10C語言小程序 數(shù)組操作示例代碼
- 01-10解析linux 文件和目錄操作的相關函數(shù)


閱讀排行
本欄相關
- 04-02c語言函數(shù)調用后清空內存 c語言調用
- 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語言調用函數(shù)求fibo C語言調用函數(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用法實例總結
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 04-02jquery與jsp,用jquery
- 01-10SublimeText編譯C開發(fā)環(huán)境設置


