亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQLite > 正文

Sqlite 常用函數 推薦

2020-01-25 19:30:29
字體:
來源:轉載
供稿:網友
Sqlite 常用函數,在實際開發中,經常遇的到。
 
 
1 、打開數據庫: 
說明:打開一個數據庫,文件名不一定要存在,如果此文件不存在, sqlite 會自動創建。第一個參數指文件名,第二個參數則是定義的 sqlite3 ** 結構體指針(關鍵數據結構),這個結構底層細節如何,您不用管它。 
int sqlite3_open( 
const char *filename, /* Database filename (UTF-8) */ 
sqlite3 **ppDb /* OUT: SQLite db handle */ 
); 
返回值:表示操所是否正確 ( SQLITE_OK 操作正常) 

2 、關閉數據庫: 
說明:如果用 sqlite3_open 開啟了一個數據庫,結尾時不要忘了用這個函數關閉數據庫。 
int sqlite3_close(sqlite3*); // 參數就是剛才的結構體,也就是數據庫句柄 

3 、執行 SQL 語句: 
說 明:這個函數的功能是執行一條或者多條 SQL 語句, SQL 語句之間用 “;” 號隔開。建議在執行一條或者多條 SQL 語句得時候,指定第三個參數回調函數,在 回調函數中可以獲得執行 Sql 得詳細過程,如果所有 Sql 執行完畢則應該返回 0 ,否則,則說明這次執行并沒有完全成功。第五個參數:如果執行失?。]有返回 0 )則可以查看第五個闡述得值。來查看詳細錯誤信息。 
int sqlite3_exec( 
sqlite3*, /* 已經打開的數據庫句柄 */ 
const char *sql, /* 要執行的 Sql 語句 */ 
sqlite_callback, /* 回調函數 */ 
void *, /* 傳遞給回調函數的參數 */ 
char **errmsg /* 保存錯誤信息 */ 
); 
通常 sqlite3_callback 和它后面的 void* 這兩個位置都可以填 NULL ,表示不需要回調。比如您做 insert 操作,做 delete 操作,就沒有必要使用回調。而當作 select 時,就要使用回調,因為 sqlite3 把數據查出來,得通過回調告訴你查出了什么數據。 

4 、 exec 的回調 
typedef int (*sqlite3_callback)(void*, int, char**, char**); 
說明:你的回調函數必須定義為上面這個函數的類型。 
例如: 
int LoadMyInfo( void * para, int n_column, char ** column_value, char ** column_name ) 

//para 是你在 sqlite3_exec 里傳入的 void * 參數 
// 通過 para 參數,你可以傳入一些特殊的指針(比如類指針、結構指針),然后在這里面強制轉換成對應的類型(這里面是 void* 類型,必須強制轉換成你的類型才可用)。然后操作這些數據 
//n_column 是這一條記錄有多少個字段 ( 即這條記錄有多少列 ) 
// char ** column_value 是個關鍵值,查出來的數據都保存在這里,它實際上是個 1 維數組(不要以為是 2 維數組),每一個元素都是一個 char * 值,是一個字段內容(用字符串來表示,以 /0 結尾) 
//char ** column_name 跟 column_value 是對應的,表示這個字段的字段名稱 

5 、取當前插入位置: 
功能:返回你前一次插入得位置,從 1 開始, sqlite3* 為你打開數據庫所得到得句柄。 
long long int sqlite3_last_insert_rowid(sqlite3*); 
6 、非回調 select 查詢: 
功能:執行一次查詢 Sql 并且返回得到一個記錄集。 
int sqlite3_get_table( 
sqlite3*, /* 已經打開的數據庫句柄 */ 
const char *sql, /* 要執行的 Sql 語句 */ 
char ***resultp, /* 保存返回記錄集的指針 */ 
int *nrow, /* 返回記錄數(及查出多少行) */ 
int *ncolumn, /* 返回字段數(多少列) */ 
char **errmsg /* 返回錯誤信息 */ 

說明:第三個參數是查詢結果,它是一維數組,內存布局為:第一行是字段名稱,后面是緊接著是每個字段的值。 
實例: 
int main( int , char ** ) 

sqlite3 * db; 
int result; 
char * errmsg = NULL; 
char **dbResult; 
int nRow, nColumn; 
int i , j; 
int index; 
result = sqlite3_open( “c://Dcg_database.db”, &db ); 
if( result != SQLITE_OK ) 

return -1; 

// 數據庫操作代碼 
// 假設前面已經創建了 MyTable_1 表 
// 開始查詢,傳入的 dbResult 已經是 char ** ,這里又加了一個 & 取地址符,傳遞進去的就成了 char *** 
result = sqlite3_get_table( db, “select * from MyTable_1”, &dbResult, &nRow, &nColumn, &errmsg ); 
if( SQLITE_OK == result ) 

// 查詢成功 
index = nColumn; // 前面說過 dbResult 前面第一行數據是字段名稱,從 nColumn 索引開始才是真正的數據 
printf( “ 查到 %d 條記錄 /n”, nRow ); 
for( i = 0; i < nRow ; i++ ) 

printf( “ 第 %d 條記錄 /n”, i+1 ); 
for( j = 0 ; j < nColumn; j++ ) 

printf( “ 字段名 :%s ?> 字段值 :%s/n”, dbResult[j], dbResult [index] ); 
++index; // dbResult 的字段值是連續的,從第 0 索引到第 nColumn - 1 索引都是字段名稱,從第 nColumn 索引開始,后面都是字段值,它把一個二維的表(傳統的行列表示法)用一個扁平的形式來表示 

printf( “-------/n” ); 


// 到這里,不論數據庫查詢是否成功,都釋放 char** 查詢結果,使用 sqlite 提供的功能來釋放 
sqlite3_free_table( dbResult ); 
// 關閉數據庫 
sqlite3_close( db ); 
return 0; 


7 、釋放查詢結果: 
功能:釋放當前查詢的記錄集所占用的內存 
void sqlite3_free_table(char **result); 

實例:( SQLite 數據庫使用回調函數的簡單 C 語言實例) 
復制代碼代碼如下:

#include <stdio.h> 
#include <sqlite3.h> 
static int callback( void *NotUsed, int argc, char **argv, char **azColName) 

int i; 
for (i=0; i<argc; i++) 

printf( "%s = %s/n" , azColName[i], argv[i] ? argv[i] : "NULL" ); 

printf( "/n" ); 
return 0; 

int main( int argc, char **argv) 

sqlite3 *db; 
char *zErrMsg = 0; 
int rc; 
if ( argc!=3 ) 

fprintf(stderr, "Usage: %s DATABASE SQL-STATEMENT/n" , argv[0]); 
return 1; 

rc = sqlite3_open(argv[1], &db); 
if ( rc ) 

fprintf(stderr, "Can't open database: %s/n" , sqlite3_errmsg(db)); 
sqlite3_close(db); 
return 1; 

rc = sqlite3_exec(db, argv[2], callback, 0, &zErrMsg); 
if ( rc!=SQLITE_OK ) 

fprintf(stderr, "SQL error: %s/n" , zErrMsg); 
sqlite3_close(db); 
return 1; 

sqlite3_close(db); 
return 0; 

編譯: 
[root@localhost test]# gcc sql.c -o sql -l sqlite3

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品国产久精国产思思| 最新国产成人av网站网址麻豆| 欧美日韩裸体免费视频| 亚洲国产中文字幕久久网| 日韩成人在线观看| 日韩电影在线观看永久视频免费网站| 精品国产电影一区| 国产成人一区二区三区小说| 欧美成人自拍视频| 亚洲天堂av图片| www.亚洲一区| xxx一区二区| 欧美精品xxx| 95av在线视频| 最新日韩中文字幕| 国产69久久精品成人| 日韩女在线观看| 国产精品v片在线观看不卡| 欧美成人精品三级在线观看| 九九久久久久久久久激情| 国产精品香蕉在线观看| 影音先锋日韩有码| 欧美老女人性生活| 国产精品成人v| 欧美肥臀大乳一区二区免费视频| 欧美黑人国产人伦爽爽爽| 在线亚洲国产精品网| 国产91精品久| 亚洲摸下面视频| 91国语精品自产拍在线观看性色| 欧美性xxxx在线播放| 青青草精品毛片| 日韩精品999| 国产精品一区=区| 伊人男人综合视频网| 91国产一区在线| 亚洲性视频网站| 国产精品69精品一区二区三区| 亚洲社区在线观看| 欧美日韩激情网| 日韩69视频在线观看| 在线视频精品一| 狠狠操狠狠色综合网| 欧美性69xxxx肥| 久久成人精品视频| 成人444kkkk在线观看| 亚洲色图13p| 久久视频这里只有精品| 亚洲自拍偷拍网址| 成人激情电影一区二区| 亚洲www视频| 91av在线网站| 成人高h视频在线| 国产一区二区三区视频免费| 最近免费中文字幕视频2019| 永久555www成人免费| 亚洲最大福利视频网站| 欧美黑人xxx| 最近2019中文字幕在线高清| 疯狂蹂躏欧美一区二区精品| 亚洲免费小视频| 这里精品视频免费| 亚洲精品在线看| 热久久美女精品天天吊色| 亚洲在线一区二区| 亚洲国产精品久久91精品| 久久精品国产欧美亚洲人人爽| 国产亚洲欧美一区| 日韩精品在线观看一区| 亚洲人精品午夜在线观看| 91免费视频国产| 久久人人爽人人爽爽久久| 色婷婷综合成人| 久久久久久亚洲精品中文字幕| 亚洲网站视频福利| 揄拍成人国产精品视频| 日韩亚洲精品电影| 国产午夜精品理论片a级探花| 一本大道久久加勒比香蕉| 欧美日韩中文字幕日韩欧美| 国产欧美日韩中文字幕在线| 久久久国产精品x99av| 91国产视频在线播放| 欧美激情视频网址| 国产欧美日韩91| 久久亚洲成人精品| 91国内在线视频| 57pao精品| 欧美高清videos高潮hd| 日本精品免费观看| 日韩欧美一区二区三区久久| 亚洲综合精品伊人久久| 久久久精品美女| 亚洲国产成人在线视频| 欧美精品在线网站| 久久久www成人免费精品张筱雨| 国产日韩欧美在线视频观看| 久久亚洲电影天堂| 最新国产精品拍自在线播放| 亚洲国产99精品国自产| 久久人人爽人人爽人人片亚洲| 原创国产精品91| 国产91热爆ts人妖在线| 国产精品偷伦免费视频观看的| 亚洲国产精品人人爽夜夜爽| 亚洲成人三级在线| 亚洲美女福利视频网站| 狠狠干狠狠久久| 91精品国产乱码久久久久久久久| 在线亚洲男人天堂| 久久久免费精品视频| 国产精品久久久| 精品国产91久久久| 久久艳片www.17c.com| 久久这里有精品视频| 中文字幕亚洲欧美| 亚洲国产精品久久久久| 精品视频中文字幕| 日韩欧美亚洲范冰冰与中字| 成人a在线视频| 伊人久久五月天| 日韩在线免费观看视频| 91亚洲精华国产精华| 91系列在线播放| 欧美激情国产高清| 亚洲3p在线观看| 欧美成aaa人片免费看| 国产欧美在线看| 视频直播国产精品| 中文字幕一区二区三区电影| 欧美日韩激情视频8区| 欧美日韩激情网| 98精品在线视频| 欧美天天综合色影久久精品| 日韩在线视频免费观看| 日韩欧美在线免费观看| 97在线视频观看| 日韩欧美在线视频免费观看| 68精品国产免费久久久久久婷婷| 久久久人成影片一区二区三区| 俺去啦;欧美日韩| 亚洲欧美在线看| 国产美女久久精品| www欧美xxxx| 黄网站色欧美视频| 日韩精品视频免费专区在线播放| 亚洲成人av中文字幕| 91在线免费视频| 亚洲电影在线看| 亚洲精品欧美极品| 九九九久久国产免费| 97碰碰碰免费色视频| xxxxx91麻豆| 国产精品一区二区久久| 亚洲天堂男人的天堂| 黑人极品videos精品欧美裸| 欧美俄罗斯乱妇| 美乳少妇欧美精品| 欧美裸身视频免费观看| 欧美午夜宅男影院在线观看| 日本欧美在线视频| 中文字幕亚洲字幕| 庆余年2免费日韩剧观看大牛| 欧洲美女7788成人免费视频|