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

首頁 > 數據庫 > SQLite > 正文

Sqlite 常用函數 推薦

2020-01-31 15:12:48
字體:
來源:轉載
供稿:網友
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在线| 成人妇女淫片aaaa视频| 日韩第一页在线| 亚洲人成电影在线播放| 欧美日韩国产一区在线| 97在线精品国自产拍中文| 欧美巨猛xxxx猛交黑人97人| 日韩欧美在线国产| 日韩精品免费视频| 成人信息集中地欧美| 久久99精品久久久久久琪琪| 国产精品69精品一区二区三区| 8x拔播拔播x8国产精品| 国产美女直播视频一区| 北条麻妃一区二区三区中文字幕| 国模极品一区二区三区| 亚洲男人第一网站| 亚洲免费视频观看| 亚洲国产精品人人爽夜夜爽| 国产精品免费视频xxxx| 亚洲国产精彩中文乱码av| 亚洲精品久久久久久久久| 性欧美暴力猛交69hd| 91影院在线免费观看视频| 97免费中文视频在线观看| 国产a级全部精品| 国产91成人在在线播放| 久久久久久久久久久成人| 欧美黑人国产人伦爽爽爽| 成人亚洲综合色就1024| 欧美特黄级在线| 久久成人精品视频| 日韩欧美国产免费播放| 久久中文字幕在线| www.日本久久久久com.| 久久成人亚洲精品| 庆余年2免费日韩剧观看大牛| 亚洲综合在线播放| 国产精品黄视频| 中文字幕精品国产| 日本高清+成人网在线观看| 中文字幕亚洲欧美一区二区三区| 日韩国产精品一区| 亚洲精品国产精品乱码不99按摩| 欧美日韩成人在线视频| 午夜精品久久久久久99热| 中文字幕精品在线视频| 国产午夜精品美女视频明星a级| 91地址最新发布| 性色av一区二区三区在线观看| 欧美成人免费一级人片100| 国产午夜精品一区二区三区| 91亚洲人电影| 久久久国产精彩视频美女艺术照福利| 国产精品爱啪在线线免费观看| 日韩欧美中文字幕在线播放| 欧美性69xxxx肥| 97av在线影院| 亚洲韩国青草视频| 91免费看视频.| 久久夜色精品国产亚洲aⅴ| 91精品啪aⅴ在线观看国产| 久久99精品久久久久久噜噜| 欧美夜福利tv在线| 91sa在线看| 国产一区二区av| 日韩在线一区二区三区免费视频| 亚洲香蕉伊综合在人在线视看| 中文字幕久精品免费视频| 久久精品在线播放| 国产精品h在线观看| 亚洲精品国精品久久99热一| 精品国偷自产在线视频99| 国产精品高潮呻吟久久av黑人| 国产精品99久久久久久久久| 亚洲一区二区三区sesese| 97涩涩爰在线观看亚洲| 51精品在线观看| 亚洲欧洲日产国码av系列天堂| 亚洲男人天堂手机在线| 国产91精品久久久| 色偷偷9999www| 欧美中文字幕在线播放| 久久精品国产v日韩v亚洲| 69av在线播放| 日韩在线播放av| 久久久久久久久久久av| 国产99久久精品一区二区 夜夜躁日日躁| 亚洲精品成a人在线观看| 成人性教育视频在线观看| 亚洲人a成www在线影院| 日韩免费在线电影| 中文字幕欧美在线| 国产精品日日摸夜夜添夜夜av| 在线播放日韩专区| 成人午夜小视频| 国产丝袜精品视频| 久久久国产视频| 欧美有码在线观看| 亚洲国产小视频| 欧美乱妇高清无乱码| 欧美在线播放视频| 日韩美女写真福利在线观看| 国产午夜精品免费一区二区三区| 亚洲国产精品资源| 亚洲精品中文字幕有码专区| 亚洲精品美女在线观看| 国产一区二区三区直播精品电影| 欧美精品在线免费观看| 91亚洲va在线va天堂va国| 91美女福利视频高清| 欧美成人午夜视频| 久久久之久亚州精品露出| www.日本久久久久com.| 亚洲欧美一区二区精品久久久| 国产成人精品在线视频| 日韩精品福利网站| 国产精品2018| 国产99久久久欧美黑人| 久久久久99精品久久久久| 日韩电影中文字幕在线| 国产成人在线精品| 亚洲无限乱码一二三四麻| 欧美国产亚洲精品久久久8v| 国内精品久久久久伊人av| www.99久久热国产日韩欧美.com| 国内精品国产三级国产在线专| 视频在线一区二区| 久久亚洲精品网站| 国内精品久久久久久| 国产91ⅴ在线精品免费观看| 亚洲男人天堂手机在线| 精品亚洲一区二区三区| 日韩av在线网站| 日韩电影免费观看中文字幕| 精品无人国产偷自产在线| 免费99精品国产自在在线| 国产精品日韩久久久久| 国产精品免费一区二区三区都可以| 久久精品国产欧美亚洲人人爽| 日韩动漫免费观看电视剧高清| 亚洲开心激情网| 亚洲男人的天堂网站| 亚洲欧美日本精品| 亚洲电影天堂av| 欧美中文在线观看国产| 国产一区二区日韩精品欧美精品| 亚洲中国色老太| 亚洲一区二区三区成人在线视频精品| 色综合影院在线| 欧美小视频在线| 日韩中文字幕视频在线观看| 亚洲欧美综合v| 国产在线观看精品一区二区三区| 97国产精品免费视频| 国产亚洲精品激情久久| 97精品国产97久久久久久春色| 国产精自产拍久久久久久蜜| 亚洲欧美在线磁力| 欧美激情中文字幕乱码免费| 成人h视频在线| 另类视频在线观看| 欧美另类69精品久久久久9999| 91沈先生作品|