青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

woaidongmao

文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
數據加載中……

SQLite常用函數

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把數據查出來,得通過回調告訴你查出了什么數據。

 

4exec的回調

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語言實例)

1.       #include <stdio.h>

2.        

3.       #include <sqlite3.h>

4.        

5.        

6.        

7.       static int callback(void *NotUsed, int argc, char **argv, char **azColName)

8.        

9.       {

10.    

11.     int i;

12.    

13.     for(i=0; i<argc; i++)

14.    

15.     {

16.    

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

18.    

19.     }

20.    

21.     printf("\n");

22.    

23.     return 0;

24.    

25.   }

26.    

27.    

28.    

29.   int main(int argc, char **argv)

30.    

31.   {

32.    

33.     sqlite3 *db;

34.    

35.     char *zErrMsg = 0;

36.    

37.     int rc;

38.    

39.    

40.    

41.     if( argc!=3 )

42.    

43.     {

44.    

45.       fprintf(stderr, "Usage: %s DATABASE SQL-STATEMENT\n", argv[0]);

46.    

47.       return 1;

48.    

49.     }

50.    

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

52.    

53.     if( rc )

54.    

55.     {

56.    

57.       fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));

58.    

59.       sqlite3_close(db);

60.    

61.       return 1;

62.    

63.     }

64.    

65.     rc = sqlite3_exec(db, argv[2], callback, 0, &zErrMsg);

66.    

67.     if( rc!=SQLITE_OK )

68.    

69.     {

70.    

71.       fprintf(stderr, "SQL error: %s\n", zErrMsg);

72.    

73.       sqlite3_close(db);

74.    

75.       return 1;

76.    

77.     }

78.    

79.     sqlite3_close(db);

80.    

81.     return 0;

82.    

83.   }

 

 

posted on 2009-06-23 15:04 肥仔 閱讀(2402) 評論(0)  編輯 收藏 引用 所屬分類: 數據庫

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美久久久久久蜜桃| 亚洲国产精品视频| 国产一区二区三区在线观看免费| 欧美激情欧美激情在线五月| 欧美成人精品高清在线播放| 欧美大片一区| 欧美日韩色一区| 国产精品久久久99| 国产中文一区| 亚洲精品九九| 亚洲午夜精品一区二区| 欧美亚洲综合另类| 美女精品网站| 亚洲精品在线免费| 亚洲综合成人在线| 欧美一区二区三区在线播放| 老司机午夜精品视频| 欧美午夜无遮挡| 精品盗摄一区二区三区| 久久精品国产在热久久| 亚洲一区国产| 久久久噜噜噜久噜久久 | 久久亚洲免费| 欧美二区视频| 国产久一道中文一区| 在线观看欧美亚洲| 亚洲一区二区三区777| 久久综合激情| 中国成人亚色综合网站| 免费亚洲视频| 黄网站色欧美视频| 亚洲欧美精品在线| 亚洲电影免费观看高清完整版| 亚洲国产精品免费| 先锋影音国产一区| 欧美色图麻豆| 亚洲国产综合在线看不卡| 性8sex亚洲区入口| 亚洲高清资源| 久久久一区二区| 国产欧美日韩亚州综合| 亚洲视频日本| 欧美二区在线观看| 欧美一区二区高清| 国产精品五区| 午夜精品福利在线观看| 亚洲乱码日产精品bd| 免费看成人av| 1024精品一区二区三区| 久久久精品国产99久久精品芒果| 亚洲人人精品| 欧美激情精品久久久久久蜜臀| 国产一区二区三区免费不卡| 午夜精品久久久久影视| 一本一本久久a久久精品牛牛影视| 欧美高清视频免费观看| 亚洲国产成人av好男人在线观看| 久久精品一区二区三区不卡牛牛| 亚洲欧美怡红院| 国产日韩欧美在线一区| 欧美中文在线视频| 香蕉视频成人在线观看| 国产精品一区二区三区乱码| 亚洲一区二区三区精品在线 | 欧美91福利在线观看| 久久高清国产| 伊人成人开心激情综合网| 噜噜噜躁狠狠躁狠狠精品视频| 久久av最新网址| 在线观看亚洲| 亚洲高清一区二| 欧美午夜视频| 欧美伊人久久| 性8sex亚洲区入口| 亚洲国产91色在线| 欧美在线免费| 久久婷婷蜜乳一本欲蜜臀| 午夜天堂精品久久久久| 国产一区二区三区在线播放免费观看 | 欧美成人久久| 欧美激情精品久久久久久久变态| 一本色道久久综合亚洲精品按摩 | 欧美精品日韩一本| 亚洲资源av| 久久精品日韩欧美| 日韩视频免费在线| 性xx色xx综合久久久xx| 亚洲国产欧美在线人成| 中文亚洲欧美| 狠狠久久综合婷婷不卡| 亚洲韩国精品一区| 国产精品www| 看片网站欧美日韩| 欧美三区在线| 久久亚洲不卡| 欧美日韩综合视频| 欧美成人午夜免费视在线看片| 欧美日韩亚洲国产一区| 久久久久久久综合狠狠综合| 欧美精品日韩综合在线| 裸体歌舞表演一区二区| 国产精品免费久久久久久| 亚洲第一狼人社区| 国产视频在线一区二区| 亚洲欧洲日本国产| 国产亚洲一区二区三区在线观看 | 久久不射网站| 夜夜嗨av一区二区三区四季av| 亚洲视频在线看| 亚洲精品在线视频观看| 久久精品国亚洲| 欧美尤物巨大精品爽| 欧美日韩国产欧| 欧美激情视频网站| 黄色国产精品一区二区三区| 中文精品在线| 亚洲另类一区二区| 久久深夜福利免费观看| 西西人体一区二区| 欧美三级视频在线| 亚洲九九精品| 亚洲精品在线电影| 久久国产精品久久精品国产| 亚洲在线观看免费| 欧美日韩一区二区免费在线观看| 欧美成人午夜激情在线| 在线观看亚洲| 麻豆亚洲精品| 亚洲欧美在线网| 国产视频一区免费看| 国产在线不卡视频| 午夜视频一区在线观看| 一本一本久久a久久精品综合妖精| 娇妻被交换粗又大又硬视频欧美| 久久国产精品一区二区三区四区 | 欧美在线观看视频一区二区三区| 欧美大片免费久久精品三p | 国产精品视频xxx| 亚洲精品影视| 亚洲国产精品ⅴa在线观看| 久久爱www久久做| 亚洲久久在线| 久久久久久久一区二区| 久久综合婷婷| 国产丝袜一区二区三区| 99亚洲精品| 亚洲欧美日本国产专区一区| 好吊一区二区三区| 久久久久综合网| 久久久精品国产99久久精品芒果| 亚洲乱码国产乱码精品精98午夜| 欧美四级电影网站| 欧美绝品在线观看成人午夜影视| 中文亚洲欧美| 欧美高清视频一二三区| 久久精品国产综合精品| 久久久久久国产精品一区| 麻豆精品视频| 国产亚洲亚洲| 欧美大尺度在线观看| 久久欧美中文字幕| 精品不卡在线| 欧美成人一区二免费视频软件| 亚洲国产天堂久久综合网| 亚洲精品一区二区三区不| 欧美精品久久久久久| 国产精品99久久99久久久二8| 午夜视频在线观看一区| 在线观看日韩av| 欧美日韩免费一区| 羞羞色国产精品| 免费观看成人www动漫视频| 一区二区三区成人精品| 国产日韩精品入口| 欧美成年视频| 欧美一级播放| 亚洲美女91| 欧美69视频| 久久九九国产精品| 一本色道久久综合狠狠躁篇的优点| 国产女精品视频网站免费| 欧美激情精品| 久久夜色精品一区| 亚洲欧美日韩视频一区| 欧美成人综合一区| 欧美亚洲在线视频| 日韩亚洲不卡在线| 极品日韩久久| 国产精品第十页| 欧美高清成人| 久久久蜜桃一区二区人| 亚洲一区二区黄色| 亚洲精品乱码久久久久久黑人| 久久亚洲精品伦理| 性18欧美另类| 亚洲一区二区在线看| 日韩视频中午一区| 亚洲国产乱码最新视频| 国自产拍偷拍福利精品免费一| 国产精品久久久久久久久久免费|