国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數(shù)據(jù)庫 > SQLite > 正文

Sqlite 常用函數(shù) 推薦

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

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

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

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

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

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

說明:第三個參數(shù)是查詢結(jié)果,它是一維數(shù)組,內(nèi)存布局為:第一行是字段名稱,后面是緊接著是每個字段的值。 
實例: 
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; 

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

// 查詢成功 
index = nColumn; // 前面說過 dbResult 前面第一行數(shù)據(jù)是字段名稱,從 nColumn 索引開始才是真正的數(shù)據(jù) 
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 的字段值是連續(xù)的,從第 0 索引到第 nColumn - 1 索引都是字段名稱,從第 nColumn 索引開始,后面都是字段值,它把一個二維的表(傳統(tǒng)的行列表示法)用一個扁平的形式來表示 

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


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


7 、釋放查詢結(jié)果: 
功能:釋放當(dāng)前查詢的記錄集所占用的內(nèi)存 
void sqlite3_free_table(char **result); 

實例:( SQLite 數(shù)據(jù)庫使用回調(diào)函數(shù)的簡單 C 語言實例) 
復(fù)制代碼代碼如下:

#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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产亚洲精品久久久网站好莱| av免费在线一区二区三区| 精品视频二区| 在线欧美一级视频| 青青青青在线| 国产免费av高清在线| 国产永久av在线| 中文字幕在线观看日本| 国产网红在线| 日本电影全部在线观看网站视频| 欧美性猛交xxxxbbbb| 丁香婷婷激情| 国产videos| 九九免费视频| 国产一级视频| 日本欧美在线视频免费观看| 最近免费中文字幕大全免费第三页| 国产羞羞视频在线观看| 在线免费观看黄色片| 中文字幕在线免费观看| 在线视频中文字幕| 国产一区二区三区美女秒播| 精品99又大又爽又硬少妇毛片| 久久久久久久久久久久久91| 国产91在线视频蝌蚪| 天堂资源在线中文| 亚洲成人av高清| 国产精彩视频在线观看免费蜜芽| 成年黄网站在线观看免费| √天堂8资源中文在线| 欧美精品久久久久久久小说| 国产青青草在线| 午夜视频在线看| 另类专区欧美| jizz性欧美| 亚洲精品影院在线| av福利在线播放| 国产成人综合亚洲欧美在| 国产乱在线观看视频| 蜜桃av网站| 麻豆av电影在线观看| 青青草在线播放| 亚洲国产精华液| 精灵使的剑舞无删减版在线观看| 国产精选在线观看| 国产九九在线| 中文字幕一区免费| 国产精品综合久久久久| 午夜视频在线| 国产一卡2卡3卡4卡网站免费| 高清视频一区二区三区四区| 黄色av网址在线免费观看| 九九精品视频在线观看九九| 开心激情五月婷婷| 黄网址在线播放免费| 国产麻豆综合视频在线观看| 天堂在线一二区| 92国产在线视频| free性亚洲| 狠狠综合久久久综合| 日本最新在线视频| 国产黄色在线看| 四虎在线免费视频| 丁香视频免费观看| 国产激情在线| 超碰免费在线观看| 国产精品久久久久久精| av在线官网| 最近中文字幕av免费高清| 国产三区视频在线观看| 亚洲永久免费网站| 丁香花视频在线观看| √8天堂资源地址中文在线| 爱福利在线视频| 国产精品视频一区二区图片| av首页在线| 69视频在线观看| 狠狠干五月天| 亚洲综合激情六月婷婷在线观看| 好男人免费精品视频| 中文字幕2020第一页| 成年网站免费入口在线观看| 在线国产一级| 国产激情小视频在线| 国产有码在线| 全网国产福利在线播放| 精品一区二区观看| 国产性一级片| 91caoporn在线| а√最新版地址在线天堂| 最近中文字幕在线中文视频| 日本福利午夜视频在线| 国产成人亚洲欧美电影| 国产精品一区二区三区高清在线| 日本卡一卡2卡3卡4精品卡网站| 伊人精品影院| 在线观看视频污| 日本免费视频www| 四虎成年永久免费网站| 四虎在线免费视频| eeuss影院www在线播放| av在线播放av| www.九九热.com| 久久久久久久久久久久久91| 日本调教视频在线观看 | av中文在线| jizz一区二区三区| 日本18视频网站| 国自产拍在线网站网址视频| 丁香视频免费观看| 国产网友自拍电影在线| 91最新在线| 欧美日韩在线中文字幕| 黄污在线观看| 国产视频在线播放| 精品国产福利一区二区在线 | 在线黄色国产电影| 天天激情综合| 91超碰免费在线| 在线天堂中文| 超碰在线网址| 国产成人天天5g影院| 思思99精品视频在线观看| 黄网址在线永久免费观看| 国产网站观看9久| 一本久中文高清| 国产中文字幕在线| 中文字幕av高清| 激情六月婷婷| 伊人久久青青草| 国产中文字幕第一页| 国产午夜精品久久久久免费视 | 天天操天天是| av男人的天堂网| 国产尤物一区二区三区| 国产成人亚洲综合小说区| 久久久久久日本一区99| 精品国产一区二区三区不卡在线| 久久精品国产亚洲a∨麻豆| 国产高清免费av在线| 欧美艹逼视频| 一区二区免费播放| 国产一级又黄| 青草av在线| 国产黄在线观看免费观看不卡| 人成在线免费视频| 亚洲精品一区中文字幕电影| 国产经典自拍视频在线观看| 国产69精品久久久久孕妇国产69久久 | 中文字幕av中文字幕| xxxx视频在线| 亚洲精品自拍区在线观看| 国产黄视频网站| 国产三区四区在线观看| 天堂亚洲精品| 国产中文字幕在线观看| 久草国产视频| 欧美艹逼视频| 久热免费视频| 久久精品最新免费国产成人| 青青草免费观看免费视频在线| 亚洲天堂久久久| 性网站在线播放| 日本电影全部在线观看网站视频 | 亚洲精品视频区| 日韩黄色成人| 老司机精品视频一区二区| 超碰97国产精品人人cao| 免费看ww视频网站入口| 国产69精品久久久久孕妇国产69久久| 超碰91在线| 国产精品一区二区婷婷| 国产乱子伦三级在线播放| 国产一二区视频| 国产xxxxx| av一本在线| 黄色片视频在线观看| 丁香婷婷在线| 国产高清在线看| 亚洲午夜久久久久中文字幕| www在线视频| 中文字幕一区免费| 国产a国产a国产a| a视频在线观看免费| 国产麻豆麻豆| 国产系列电影在线播放网址| av网址在线播放| 国产剧情av在线| 国产极品美女到高潮| www狠狠操| 国产精品伦理一区二区三区 | 男人天堂v视频| 午夜视频免费在线观看| 精品国产美女福利到在线不卡 | 日本成人在线播放| 国产激情网址| 久久av少妇| 伊人222成人综合网| 国产偷倩在线播放| eeuss影院在线观看第一页|