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

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

Sqlite 常用函數(shù) 推薦

2020-01-31 15:12:48
字體:
供稿:網(wǎ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 ** ,這里又加了一個 & 取地址符,傳遞進去的就成了 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ā)表
97婷婷涩涩精品一区| 欧美亚洲在线视频| 国产夫绿帽单男3p精品视频| julia一区二区中文久久94| 免费在线观看污视频| 久久久久久国产精品免费播放| 精品亚洲一区二区三区四区五区高| 国产精品国产三级国产专区53| 欧美成人艳星乳罩| 日韩欧美视频一区二区| 色欲av无码一区二区三区| 欧美一区二区三区不卡视频| 久久网福利资源网站| 三级在线观看网站| 欧美日韩高清在线| 国产成人精品一区二区三区| 欧美亚洲国产日本| 欧美男男激情freegay| 亚洲精品午夜| 日韩女同一区二区三区| 欧美精品一区二区三区四区五区| 久久精品一区二区三区不卡免费视频| 欧美a级网站| 一区二区三区不卡在线视频| 最新中文字幕免费视频| 欧美福利视频在线观看| 久久久久亚洲精品一区二区三区| 一区二区91| 97人妻精品一区二区三区视频| 精品少妇一区二区三区在线| 亚洲一区二区日本| 一区国产精品| 国内精品久久久| av在线电影免费观看| 国产小黄视频| 国产女人在线视频| 欧美激情乱人伦一区| 亚洲综合在线一区| 成人av在线一区二区| xxx欧美xxx| 欧美疯狂做受xxxx富婆| 国产又色又爽又黄刺激在线视频| 欧美成人短视频| 国产精品久久影院| 99国产精品视频免费观看| 91麻豆免费在线观看| 99精品视频免费看| 在线不卡一区二区三区| 日韩三级免费看| 日本特黄a级片| 伊人色综合网| av高清一区| 91p0rn永久地址| 欧美h片在线观看| 超污视频在线播放| 在线视频自拍| 日本高清不卡aⅴ免费网站| 国产精品91一区| 欧美xxxxbbbb| 国产91成人在在线播放| 国产一区二区三区影视| 日韩精品视频在线看| 国产精品色婷婷| 欧美一区二区三区播放老司机| 欧美日韩成人一区| 日本一区二区三区四区视频| 无码精品黑人一区二区三区| 亚洲精品一区二区三区蜜桃下载| 91探花福利精品国产自产在线| 精品国产一区二区三区不卡| 成人高清视频观看www| 欧美亚洲国产激情| 精品亚洲porn| 国内精品久久国产| 亚洲无线一线二线三线区别av| 一区二区三区在线观看动漫| 国产视频一区二区| 欧美成人激情免费网| 成人日韩av在线| 欧洲vodafonewi精品| 国产精品成人久久久| 久久看人人爽人人| 国产成人免费观看| 欧美丝袜足交| 中文字幕一区二区久久人妻| 国产欧美二区| www.激情五月.com| 亚洲精品一区二区三区影院忠贞| 91麻豆视频网站| 蜜桃91在线| 国产理论片在线观看| 欧美丰满日韩| 成人av网站观看| 国产精久久一区二区三区| 欧美亚洲精品在线观看| 偷拍自拍在线视频| 永久免费黄色片| 偷拍自拍一区| 五月天欧美精品| 激情五月播播久久久精品| 在线毛片观看| 欧美一区二区三区四区在线| 色婷婷亚洲一区二区三区| 欧美一区二区在线视频| 国产精品久久毛片| 日韩一区在线视频| 特大黑人娇小亚洲女mp4| 国产精品久久久久久妇女6080| 久久99成人| 69av成人| 日韩私人影院| 在线综合视频| a级毛片免费| 欧美高清视频在线| 91精品国产高清91久久久久久| 亚洲同性同志一二三专区| 久久精品视频va| av先锋影音少妇| 精品国产1区二区| 亚洲一区三区在线观看| 国产精品女同互慰在线看| 国精产品一区一区二区三区mba| 韩国三级hd中文字幕有哪些| 精品少妇一区二区三区日产乱码| www.在线成人| 蜜臀国产一区二区三区在线播放| 日韩免费毛片| av福利导福航大全在线| 久草亚洲一区| 色啪免费观看视频| 欧美女同在线观看| 精品久久福利| 国内成+人亚洲+欧美+综合在线| 激情懂色av一区av二区av| 国产无套内射又大又猛又粗又爽| 美国毛片一区二区| 久久中文久久字幕| 色噜噜国产精品视频一区二区| 26uuu另类欧美| 中文字幕精品视频在线观看| yw3121.龙物视频永不失联| 在线精品视频在线观看高清| 亚洲影音一区| 99人久久精品视频最新地址| 一个人免费播放在线视频看片| 亚洲综合视频一区| 在线视频观看国产| 受虐m奴xxx在线观看| 亚洲成av人片观看| 中文字幕第五页| 99在线视频播放| 国产国语videosex另类| 在线播放国产区| 免费黄视频在线观看| 先锋影音av321| 女主播福利一区| 欧美美女18p| 午夜福利视频一区二区| 黄色片一区二区| 亚洲av成人无码久久精品老人| 日韩欧美aⅴ综合网站发布| 一区二区免费在线播放| 99re91这里只有精品| 快射av在线播放一区| 国产精品一区二区黑丝| 国产一区二区三区在线观看免费视频| 蜜桃麻豆av在线| 日本黄色一区二区三区| 国产激情美女久久久久久吹潮| 欧美激情在线一区二区三区| 国产一级片免费看| 天堂中文资源在线| 国产精品三级久久久久久电影| 超黄网站在线观看| 亚洲国产97在线精品一区| 中文字幕国产在线观看| 日韩电影网在线| 亚洲电影网站| 亚洲欧美精品一区二区三区| 国产精品视频免费观看| 日韩亚洲欧美中文在线| 超免费在线视频| 丁香花高清在线观看完整版| 久久精品久久精品亚洲人| 国产片在线播放| 蜜臀av亚洲一区中文字幕| 青青草原网站在线观看| 制服.丝袜.亚洲.中文.综合| 久久99精品网久久| 精品极品三级久久久久| 国产成人精品一区二区三区视频| 欧美成人三级视频| 久久久精品人体av艺术| 91精品国产综合久久福利| 欧美日韩一区二区三区不卡视频| 国产成人一区二区精品非洲| 国产69精品久久久久毛片| 天天噜天天色| 91国模大尺度私拍在线视频| 久久一夜天堂av一区二区三区| 国产色91在线| 国产一级在线观看| 日本精品久久久久久久久久| 玩弄中年熟妇正在播放| 美女脱光内衣内裤| 国产精品99久久久久久宅男| 手机在线视频一区| 久久精品国产亚洲av麻豆| 国产成人在线亚洲欧美| 五月天激情综合| 久久久精品网| 成人爽a毛片免费啪啪红桃视频| 68精品久久久久久欧美| 黄色在线视频网站| 成人国内精品久久久久一区| 精品国产伦一区二区三区免费| 免费看一区二区三区| 极品人妻一区二区三区| 99国产精品久久久久久久成人热| 欧美成人日韩| 黄色av地址| 精品国产视频在线| 少妇高潮久久久久久潘金莲| 免费在线黄色网| 最近中文字幕在线观看| 欧美aa免费在线| 77777在线| 国产成人精品视频| 色婷婷激情综合| 国产精品欧美三级在线观看| 手机看片福利盒子久久| 久久狠狠一本精品综合网| 97精品视频在线观看| 亚洲成人久久电影| 91精品视频在线| 亚洲精品乱码久久久久| 在线一区观看| 日韩精品一区二区三区在线视频| 色噜噜狠狠一区二区三区| 中文字幕av不卡在线| 国产在线精品二区| 欧美激情视频在线| a v视频在线观看| 欧美午夜一区二区三区| www国产精品| 色综合伊人色综合网| 成人一区在线观看| 啦啦啦免费高清视频在线观看| 日本黄色录像视频| 福利视频久久| 熟妇人妻中文av无码| 林心如三级全黄裸体| 中文字字幕在线中文乱码电影| 狠狠色综合色区| 精品乱色一区二区中文字幕| 猫咪成人在线观看| 香蕉视频免费在线| 女人丝袜激情亚洲| 亚洲欧美综合一区二区| 在线观看污视频| 欧美深夜福利视频| 精品国产亚洲一区二区三区在线观看| 青青草久久网络| 日韩精品欧美精品| 色综合久久久久综合体桃花网| 啦啦啦免费高清视频在线观看| 日韩国产在线一| 久久久精品视频在线观看| 一区二区三区欧美日| 自拍偷拍亚洲精品| 欧美一级二级三级| av久久久久久| 亚洲综合日韩中文字幕v在线| 欧美性受xxxxxx黑人xyx性爽| 日本一区二区三区视频在线播放| 欧美一区二区在线| 成人一道本在线| 国产精品日韩一区二区| 成人18精品视频| 黄色三级视频在线观看| 国产一级免费大片| 开心丁香婷婷深爱五月| 日本韩国欧美精品大片卡二| 丰满诱人av在线播放| 欧美激情偷拍自拍| x88av在线| 黄在线观看免费网站ktv| 中文字幕在线视频久| 国产精品国模在线| 怡红院在线播放| 精品88久久久久88久久久| 久久久9999久久精品小说| 亚洲欧洲一区二区天堂久久| 精品国产www| 国产午夜精品久久久| 欧美日韩在线三级| 日韩精品亚洲一区| 一级网站免费观看| 国产精品18久久久久久麻辣| 亚洲人成在线网站| 免费久久久一本精品久久区| 自由色视频.| 日本一区二区三区精品| 99久久www免费| 亚洲 日本 欧美 中文幕| 欧美在线极品| 综合国产精品| 尤物视频在线免费观看| 精品久久久久久久久中文字幕| 亚洲亚裔videos黑人hd| 在线观看污污视频| 999久久久精品国产| 182tv在线播放| 最近中文字幕在线6| 中文字幕网站在线观看| 久久精品日产第一区二区| 免费看日本黄色片| 久草免费在线色站| 激情五月综合色婷婷一区二区| 久久一区二区免费播放| 18以下岁禁止1000部免费| 国产婷婷在线观看| 亚洲男人天堂网站| 亚洲中国最大av网站| 亚洲福利视频网站| 国产免费福利| 成人免费小视频| 日本欧美一区二区三区不卡视频|