婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Sqlite 常用函數 推薦

Sqlite 常用函數 推薦

熱門標簽:電話機器人錄音師薪資 中國地圖標注省份用什么符號 孝感銷售電銷機器人廠家 高德地圖標注電話怎么沒了 奧維地圖標注字體大小修改 北京智能外呼系統供應商家 無錫梁溪公司怎樣申請400電話 智能電銷機器人教育 江西穩定外呼系統供應商
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; iargc; 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
您可能感興趣的文章:
  • Android開發之SQLite的使用方法
  • SQLite 中文指南之FAQ
  • SQLite中的B-Tree實現細節分析
  • sqlite中文亂碼問題原因分析及解決
  • SQLite3中的日期時間函數使用小結
  • sqlite3 top的查詢及limit語法介紹
  • SQLite優化方法
  • SQLite 錯誤碼整理
  • sQlite常用語句以及sQlite developer的使用與注冊

標簽:通化 臨滄 那曲 海北 阜陽 齊齊哈爾 荊州 泰州

巨人網絡通訊聲明:本文標題《Sqlite 常用函數 推薦》,本文關鍵詞  Sqlite,常用,函數,推薦,Sqlite,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Sqlite 常用函數 推薦》相關的同類信息!
  • 本頁收集關于Sqlite 常用函數 推薦的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    中文字幕一区二区三区在线播放 | 色综合久久久久久久久| 玉米视频成人免费看| 国产一区二区三区黄视频 | 欧美三级一区二区| 亚洲一区二区视频| 91精品国产综合久久精品| 一区二区三区中文免费| 国产欧美精品一区二区色综合朱莉| 日韩一区二区三| 国产成人高清视频| 国产一区二区视频在线播放| 国产精品国产三级国产aⅴ中文 | 国产精品色一区二区三区| 日韩久久久久久| 久久久久久久久久久电影| 精品久久久久香蕉网| 欧美老肥妇做.爰bbww| 精品久久久久久亚洲综合网| 久久理论电影网| 1000精品久久久久久久久| 自拍偷拍亚洲激情| 国产清纯白嫩初高生在线观看91| 中文一区一区三区高中清不卡| 中国色在线观看另类| 欧美精品v国产精品v日韩精品| 国产乱对白刺激视频不卡| 91麻豆福利精品推荐| 欧美影院一区二区| 国产精品99久久不卡二区| 国产成人av福利| 国产激情偷乱视频一区二区三区 | 国产亚洲一二三区| 精品国产一区久久| 欧美日本国产视频| 欧美精品一区二| 亚洲成人在线观看视频| 国产一区久久久| 欧美电影免费观看高清完整版在线 | 国产精品国产三级国产有无不卡 | 亚洲欧洲成人自拍| 依依成人精品视频| 精品国产欧美一区二区| 亚洲色图都市小说| 欧美理论电影在线| 91福利国产成人精品照片| 久久综合久久综合九色| 亚洲精品一二三| 国产乱子轮精品视频| 欧美美女喷水视频| 欧美日韩一区视频| 欧美激情资源网| 午夜免费久久看| www.成人在线| 欧美激情中文字幕一区二区| 亚洲国产精品久久久久婷婷884| 久久99国产精品成人| 3751色影院一区二区三区| 久久久久国产免费免费| 午夜精品久久久久久久99水蜜桃 | 99精品黄色片免费大全| 欧美一级爆毛片| 国产精品丝袜在线| www.欧美色图| 日韩电影在线一区二区| 日产国产欧美视频一区精品| 欧美久久一二区| 18成人在线观看| 欧美日韩国产精选| 亚洲一区二三区| 亚洲欧洲在线观看av| 三级一区在线视频先锋| 久久久久国产成人精品亚洲午夜| 伊人夜夜躁av伊人久久| 91亚洲精华国产精华精华液| 日韩一区二区三区免费看 | 2024国产精品| 91在线一区二区三区| 不卡一卡二卡三乱码免费网站| 性做久久久久久久久| 国产乱国产乱300精品| 欧美一级黄色录像| 欧美三级电影网| 偷拍亚洲欧洲综合| 91蝌蚪porny| 91久久精品一区二区三| 美女诱惑一区二区| 欧美一区二区在线观看| 成人黄色在线网站| 老司机午夜精品99久久| 久久中文字幕电影| 欧美亚洲综合在线| 天堂va蜜桃一区二区三区 | 亚洲男人的天堂在线aⅴ视频| 欧美亚洲动漫精品| 精品一区二区免费| 婷婷六月综合亚洲| 韩国v欧美v日本v亚洲v| 欧美精品一区二| 亚洲国产裸拍裸体视频在线观看乱了| 91麻豆精品91久久久久同性| 69p69国产精品| 欧美一卡2卡3卡4卡| 国产成人免费网站| 欧美日韩欧美一区二区| 国产尤物一区二区| 午夜影院久久久| 国产性天天综合网| 亚洲一区二区不卡免费| 日日摸夜夜添夜夜添国产精品| 一区二区三区四区不卡在线| 日韩高清欧美激情| 国产精品成人一区二区三区夜夜夜| 日韩欧美视频一区| 久久伊99综合婷婷久久伊| 成人一二三区视频| 国产乱人伦偷精品视频不卡| 五月婷婷激情综合| 国产精品黄色在线观看| 一区二区三区四区不卡视频| 色系网站成人免费| 亚洲综合色在线| 久久精品一区二区三区av| caoporen国产精品视频| 狠狠色2019综合网| 成人福利在线看| 欧美三级三级三级| 亚洲美女视频在线| 亚洲一区精品在线| 国产尤物一区二区| 亚洲免费观看在线视频| 91免费版pro下载短视频| 粉嫩一区二区三区在线看| 2022国产精品视频| 亚洲电影在线免费观看| 91精品国产乱| 亚洲一区二区三区在线看| 蜜桃视频免费观看一区| 国产成人免费在线观看| 欧美高清dvd| 亚洲特级片在线| 蜜臀av一级做a爰片久久| 欧美三级欧美一级| 粉嫩久久99精品久久久久久夜| 国产麻豆成人精品| 日韩一二三区视频| 国产欧美日本一区视频| 麻豆视频观看网址久久| 亚洲国产精品久久久久婷婷884 | 激情五月婷婷综合网| 在线免费不卡电影| 亚洲一区二区三区在线| 精品国产精品网麻豆系列| 91视频精品在这里| 五月天久久比比资源色| 日韩欧美123| 国模一区二区三区白浆| 久久噜噜亚洲综合| 国产精品一区二区在线看| 精品国产免费人成在线观看| 亚洲猫色日本管| 欧美xfplay| 一道本成人在线| 午夜久久久久久电影| 日本一区二区电影| 欧美三级日韩三级国产三级| 亚洲激情成人在线| 国产亚洲欧洲一区高清在线观看| 欧美性生活一区| 欧美美女喷水视频| 欧美在线视频日韩| 国产精品99久久久| 国产精品久久久久久久久免费相片| 91精品国产入口| 91女神在线视频| 亚洲一区影音先锋| 国产精品国产三级国产普通话99 | 日韩一区欧美二区| 日韩一级完整毛片| 91国内精品野花午夜精品| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲私人黄色宅男| 国产精品私人影院| 成人黄色国产精品网站大全在线免费观看 | 国产精品福利在线播放| 欧美一区二视频| 高清国产一区二区| 国产一区二区福利| 欧美变态口味重另类| 一区二区三区四区视频精品免费| 欧美日韩一级黄| 欧美性猛交xxxxxx富婆| 欧美电视剧在线看免费| 色女孩综合影院| 91麻豆蜜桃一区二区三区| 91精品国产高清一区二区三区| 欧美精品丝袜中出| 欧美va在线播放| 久久九九全国免费| 亚洲欧洲www|