SQLite 參數化查詢


SQLite參數化查詢

首先給出兩個參考博客:

Sqlite DB

sqlite3使用簡介

貼出一段自己用的代碼:

#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>


int main(int argc, char* argv[])
{
   sqlite3 *db;
   char *zErrMsg = 0;
   int rc;
   char *sql;
   const char* data = "Callback function called";
   sqlite3_stmt *res;
   /* Open database */
   rc = sqlite3_open("test.db", &db);
   if( rc ){
      fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
      exit(0);
   }else{
      fprintf(stderr, "Opened database successfully\n");
   }
   /* Create SQL statement */
   sql = "SELECT count(*) from COMPANY WHERE ID = ? AND AGE = '32'";

   /* Execute SQL statement */
   rc = sqlite3_prepare_v2(db, sql, -1, &res, 0);
    if (rc == SQLITE_OK)
     {
        sqlite3_bind_int(res, 1, 1);//查詢第一個問好處ID為1的條目
        printf("bind success!\n");
    } 
    else {
        fprintf(stderr, "Failed to execute statement: %s\n", sqlite3_errmsg(db));
    }
    int step = sqlite3_step(res);
   if (step == SQLITE_ROW) {
      printf("%d: ", sqlite3_column_int(res, 0));    //sqlite3_column_* 有多種形式
      //printf("%s\n", sqlite3_column_text(res, 1));//若存在第二個問號,需要此句,但本處不需要
    }
    sqlite3_finalize(res);
    sqlite3_close(db);
    return 0;
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM