C語言連接MySQL資料庫

對很多C/C++程式設計師來說,操作MySQL資料庫是一個技術難點,本文講述採用freecplus開源框架操作MySQL資料庫,freecplus框架是C語言技術網作者二十年的技術積累,功能強大,簡單易用。

一、源程式碼說明

freecplus是一個Linux系統下的C/C++開源框架,源程式碼請前往C語言技術網(www.freecplus.net)下載。

本文介紹的是freecplus框架中採用connection和sqlstatement類操作MySQL資料庫。

類的聲明文件是freecplus/db/mysql/_mysql.h。

類的定義文件是freecplus/db/mysql/_mysql.cpp。

示常式序位於freecplus/db/mysql目錄中。

編譯規則文件是freecplus/db/mysql/makefile。

二、概述

本文不會介紹MySQL資料庫、SQL語言和C/C++的基礎知識,您應該是一個職業的C/C++程式設計師,在閱讀本文之前,您已經掌握了MySQL資料庫和SQL語言的基礎知識。

freecplus框架把MySQL提供的庫函數封裝成了connection和sqlstatement類,採用封裝後的類操作MySQL資料庫,程式碼簡潔優雅,性能卓越。

接下來我先列出connection和sqlstatement類的聲明,然後通過流程圖和示常式序介紹它位的用法。

三、connection類

MySQL資料庫連接connection類的聲明(程式設計師不必關心的私有成員和數據結構未列出):

// MySQL資料庫連接池類。  class connection  {  public:    int m_state;         // 與資料庫的連接狀態,0-未連接,1-已連接。      CDA_DEF m_cda;       // 資料庫操作的結果或最後一次執行SQL語句的結果。      char m_sql[10241];   // SQL語句的文本,最長不能超過10240位元組。      connection();        // 構造函數。   ~connection();        // 析構函數。      // 登錄資料庫。    // connstr:資料庫的登錄參數,格式:"ip,username,password,dbname,port",    // 例如:"172.16.0.15,qxidc,qxidcpwd,qxidcdb,3306"。    // charset:資料庫的字符集,如"gbk",必須與資料庫保持一致,否則會出現中文亂碼的情況。    // autocommitopt:是否啟用自動提交,0-不啟用,1-啟用,預設是不啟用。    // 返回值:0-成功,其它失敗,失敗的程式碼在m_cda.rc中,失敗的描述在m_cda.message中。    int connecttodb(char *connstr,char *charset,unsigned int autocommitopt=0);      // 提交事務。    // 返回值:0-成功,其它失敗,程式設計師一般不必關心返回值。    int commit();      // 回滾事務。    // 返回值:0-成功,其它失敗,程式設計師一般不必關心返回值。    int  rollback();      // 斷開與資料庫的連接。    // 注意,斷開與資料庫的連接時,全部未提交的事務自動回滾。    // 返回值:0-成功,其它失敗,程式設計師一般不必關心返回值。    int disconnect();      // 執行SQL語句。    // 如果SQL語句不需要綁定輸入和輸出變數(無綁定變數、非查詢語句),可以直接用此方法執行。    // 參數說明:這是一個可變參數,用法與printf函數相同。    // 返回值:0-成功,其它失敗,失敗的程式碼在m_cda.rc中,失敗的描述在m_cda.message中,    // 如果成功的執行了非查詢語句,在m_cda.rpc中保存了本次執行SQL影響記錄的行數。    // 程式設計師必須檢查execute方法的返回值。    // 在connection類中提供了execute方法,是為了方便程式設計師,在該方法中,也是用sqlstatement類來完成功能。    int execute(const char *fmt,...);  };  

四、sqlstatement類

MySQL資料庫的SQL語句操作sqlstatement類的聲明(程式設計師不必關心的私有成員和數據結構未列出):

// 操作SQL語句類。  class sqlstatement  {  public:    int m_state;         // 與資料庫連接池的綁定狀態,0-未綁定,1-已綁定。      char m_sql[10241];   // SQL語句的文本,最長不能超過10240位元組。      CDA_DEF m_cda;       // 執行SQL語句的結果。      sqlstatement();      // 構造函數。    sqlstatement(connection *conn);    // 構造函數,同時綁定資料庫連接池。   ~sqlstatement();      // 析構函數。      // 綁定資料庫連接池。    // conn:資料庫連接池connection對象的地址。    // 返回值:0-成功,其它失敗,只要conn參數是有效的,並且資料庫的游標資源足夠,connect方法不會返回失敗。    // 程式設計師一般不必關心connect方法的返回值。    // 注意,每個sqlstatement只需要綁定一次,在綁定新的connection前,必須先調用disconnect方法。    int connect(connection *conn);      // 取消與資料庫連接池的綁定。    // 返回值:0-成功,其它失敗,程式設計師一般不必關心返回值。    int disconnect();      // 準備SQL語句。    // 參數說明:這是一個可變參數,用法與printf函數相同。    // 返回值:0-成功,其它失敗,程式設計師一般不必關心返回值。    // 注意:如果SQL語句沒有改變,只需要prepare一次就可以了。    int prepare(const char *fmt,...);      // 綁定輸入變數的地址。    // position:欄位的順序,從1開始,必須與prepare方法中的SQL的序號一一對應。    // value:輸入變數的地址,如果是字元串,記憶體大小應該是表對應的欄位長度加1。    // len:如果輸入變數的數據類型是字元串,用len指定它的最大長度,建議採用表對應的欄位長度。    // 返回值:0-成功,其它失敗,程式設計師一般不必關心返回值。    // 注意:1)如果SQL語句沒有改變,只需要bindin一次就可以了,2)綁定輸入變數的總數不能超過256個。    int bindin(unsigned int position,int    *value);    int bindin(unsigned int position,long   *value);    int bindin(unsigned int position,unsigned int  *value);    int bindin(unsigned int position,unsigned long *value);    int bindin(unsigned int position,float *value);    int bindin(unsigned int position,double *value);    int bindin(unsigned int position,char   *value,unsigned int len);      // 綁定輸出變數的地址。    // position:欄位的順序,從1開始,與SQL的結果集一一對應。    // value:輸出變數的地址,如果是字元串,記憶體大小應該是表對應的欄位長度加1。    // len:如果輸出變數的數據類型是字元串,用len指定它的最大長度,建議採用表對應的欄位長度。    // 返回值:0-成功,其它失敗,程式設計師一般不必關心返回值。    // 注意:1)如果SQL語句沒有改變,只需要bindout一次就可以了,2)綁定輸出變數的總數不能超過256個。    int bindout(unsigned int position,int    *value);    int bindout(unsigned int position,long   *value);    int bindout(unsigned int position,unsigned int  *value);    int bindout(unsigned int position,unsigned long *value);    int bindout(unsigned int position,float *value);    int bindout(unsigned int position,double *value);    int bindout(unsigned int position,char   *value,unsigned int len);      // 執行SQL語句。    // 返回值:0-成功,其它失敗,失敗的程式碼在m_cda.rc中,失敗的描述在m_cda.message中。    // 如果成功的執行了非查詢語句,在m_cda.rpc中保存了本次執行SQL影響記錄的行數。    // 程式設計師必須檢查execute方法的返回值。    int execute();      // 執行SQL語句。    // 如果SQL語句不需要綁定輸入和輸出變數(無綁定變數、非查詢語句),可以直接用此方法執行。    // 參數說明:這是一個可變參數,用法與printf函數相同。    // 返回值:0-成功,其它失敗,失敗的程式碼在m_cda.rc中,失敗的描述在m_cda.message中,    // 如果成功的執行了非查詢語句,在m_cda.rpc中保存了本次執行SQL影響記錄的行數。    // 程式設計師必須檢查execute方法的返回值。    int execute(const char *fmt,...);      // 從結果集中獲取一條記錄。    // 如果執行的SQL語句是查詢語句,調用execute方法後,會產生一個結果集(存放在資料庫的緩衝區中)。    // next方法從結果集中獲取一條記錄,把欄位的值放入已綁定的輸出變數中。    // 返回值:0-成功,1403-結果集已無記錄,其它-失敗,失敗的程式碼在m_cda.rc中,失敗的描述在m_cda.message中。    // 返回失敗的原因主要有兩個:1)與資料庫的連接已斷開;2)綁定輸出變數的記憶體太小。    // 每執行一次next方法,m_cda.rpc的值加1。    // 程式設計師必須檢查next方法的返回值。    int next();  };  

五、程式流程

freecplus框架把對MySQL資料庫操作的SQL語句分為兩種:有結果集的SQL語句和無結果集的SQL語句。

如果SQL語句被執行後,有結果集的產生,稱為有結果集的SQL,即數據查詢語言DQL,以select關鍵字,各種簡單查詢,連接查詢等都屬於DQL。

如果SQL語句被執行後,沒有結果集的產生,稱為無結果集的SQL,包括數據定義語言DDL(主要是create、drop和alter)和數據操縱語言DML(insert、update和insert)。

也可以這麼說,查詢的SQL語句會產生結果集,其它的SQL語句不會產生結果集。

1、無結果集SQL的程式的流程

在這裡插入圖片描述

這是一個完程的流程,在實際開發中,如果是執行簡單的SQL語句,第6步和第7步可能不需要,如果SQL語句只執行一次,第7步和第8步之間的循環也不需要。

2、有結果集SQL的程式的流程

在這裡插入圖片描述

這是一個完程的流程,在實際開發中,如果是執行簡單的查詢語句,第6步、第7步和第8步可能不需要,如果結果集中最多只有一條記錄,第10步和第11步之間的循環也不需要。

六、示常式序

1、創建超女資訊表

示例(createtable.cpp)

/*   *  程式名:createtable.cpp,此程式演示freecplus框架操作MySQL資料庫(創建表)。   *  作者:C語言技術網(www.freecplus.net) 日期:20190525  */  #include "_mysql.h"   // freecplus框架操作MySQL的頭文件。    int main(int argc,char *argv[])  {    connection conn; // 資料庫連接類      // 登錄資料庫,返回值:0-成功,其它-失敗。    // 失敗程式碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。    if (conn.connecttodb("172.16.0.15,root,123qweASD!@#,mysql,3306","gbk") != 0)    {      printf("connect database failed.n%sn",conn.m_cda.message); return -1;    }      sqlstatement stmt(&conn); // 操作SQL語句的對象。      // 準備創建表的SQL語句。    // 超女表girls,超女編號id,超女姓名name,體重weight,報名時間btime,超女說明memo,超女圖片pic。    stmt.prepare("      create table girls(id    bigint(10),                         name  varchar(30),                         weight   decimal(8,2),                         btime datetime,                         memo  longtext,                         pic   longblob,                         primary key (id))");    // prepare方法不需要判斷返回值。      // 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。    // 失敗程式碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。    if (stmt.execute() != 0)    {      printf("stmt.execute() failed.n%sn%sn",stmt.m_sql,stmt.m_cda.message); return -1;    }      printf("create table girls ok.n");  }  

運行效果

在這裡插入圖片描述

2、向超女表中插入5條記錄

示例(inserttable.cpp)

/*   *  程式名:inserttable.cpp,此程式演示freecplus框架操作MySQL資料庫(向表中插入5條記錄)。   *  作者:C語言技術網(www.freecplus.net) 日期:20190525  */  #include "_mysql.h"   // freecplus框架操作MySQL的頭文件。    // 定義用於超女資訊的結構,與表中的欄位對應。  struct st_girls  {    long id;        // 超女編號,用long數據類型對應Oracle無小數的number(10)。    char name[11];  // 超女姓名,用char[31]對應Oracle的varchar2(30)。    double weight;  // 超女體重,用double數據類型對應Oracle有小數的number(8,2)。    char btime[20]; // 報名時間,用char對應Oracle的date,格式:'yyyy-mm-dd hh24:mi:ssi'。  } stgirls;    int main(int argc,char *argv[])  {    connection conn; // 資料庫連接類      // 登錄資料庫,返回值:0-成功,其它-失敗。    // 失敗程式碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。    if (conn.connecttodb("172.16.0.15,root,123qweASD!@#,mysql,3306","gbk") != 0)    {      printf("connect database failed.n%sn",conn.m_cda.message); return -1;    }      sqlstatement stmt(&conn); // 操作SQL語句的對象。      // 準備插入表的SQL語句。    stmt.prepare("      insert into girls(id,name,weight,btime)                 values(:1,:2,:3,str_to_date(:4,'%%Y-%%m-%%d %%h:%%i:%%s'))");    // 也可以用以下一行程式碼代替上面這行程式碼,兼容oracle資料庫。    //            values(:1,:2,:3,to_date(:4,'yyyy-mm-dd hh24:mi:ss'))");    // prepare方法不需要判斷返回值。    // 為SQL語句綁定輸入變數的地址,bindin方法不需要判斷返回值。    stmt.bindin(1,&stgirls.id);    stmt.bindin(2, stgirls.name,10);    stmt.bindin(3,&stgirls.weight);    stmt.bindin(4, stgirls.btime,19);      // 模擬超女數據,向表中插入5條測試資訊。    for (int ii=1;ii<=5;ii++)    {      memset(&stgirls,0,sizeof(stgirls)); // 結構體變數初始化。        // 為結構體變數的成員賦值。      stgirls.id=ii;                                 // 超女編號。      sprintf(stgirls.name,"超女%02d",ii);           // 超女姓名。      stgirls.weight=ii*2.11;                        // 超女體重。      strcpy(stgirls.btime,"2018-03-01 12:25:31");   // 報名時間。        // 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。      // 失敗程式碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。      if (stmt.execute() != 0)      {        printf("stmt.execute() failed.n%sn%sn",stmt.m_sql,stmt.m_cda.message); return -1;      }        printf("成功插入了%ld條記錄。n",stmt.m_cda.rpc); // stmt.m_cda.rpc是本次執行SQL影響的記錄數。    }      printf("insert table girls ok.n");      conn.commit(); // 提交資料庫事務。  }  

運行效果

在這裡插入圖片描述

3、更新超女表中的記錄

示例(updatetable.cpp)

/*   *  程式名:updatetable.cpp,此程式演示freecplus框架操作MySQL資料庫(修改表中的記錄)。   *  作者:C語言技術網(www.freecplus.net) 日期:20190525  */  #include "_mysql.h"   // freecplus框架操作MySQL的頭文件。    int main(int argc,char *argv[])  {    connection conn; // 資料庫連接類      // 登錄資料庫,返回值:0-成功,其它-失敗。    // 失敗程式碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。    if (conn.connecttodb("172.16.0.15,root,123qweASD!@#,mysql,3306","gbk") != 0)    {      printf("connect database failed.n%sn",conn.m_cda.message); return -1;    }      sqlstatement stmt(&conn); // 操作SQL語句的對象。      char strbtime[20];  // 用於存放超女的報名時間。    memset(strbtime,0,sizeof(strbtime));    strcpy(strbtime,"2019-12-20 09:45:30");      // 準備更新數據的SQL語句,不需要判斷返回值。    stmt.prepare("      update girls set btime=str_to_date(:1,'%%Y-%%m-%%d %%h:%%i:%%s') where id>=2 and id<=4");    // 也可以用以下一行程式碼代替上面這行程式碼,兼容oracle資料庫。    //  update girls set btime=to_date(:1,'yyyy-mm-dd hh24:mi:ss') where id>=2 and id<=4");    // prepare方法不需要判斷返回值。    // 為SQL語句綁定輸入變數的地址,bindin方法不需要判斷返回值。    stmt.bindin(1,strbtime,19);    // 如果不採用綁定輸入變數的方法,把strbtime的值直接寫在SQL語句中也是可以的,如下:    /*    stmt.prepare("      update girls set btime=to_date('%s','yyyy-mm-dd hh24:mi:ss') where id>=2 and id<=4",strbtime);    */      // 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。    // 失敗程式碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。    if (stmt.execute() != 0)    {      printf("stmt.execute() failed.n%sn%sn",stmt.m_sql,stmt.m_cda.message); return -1;    }      // 請注意,stmt.m_cda.rpc變數非常重要,它保存了SQL被執行後影響的記錄數。    printf("本次更新了girls表%ld條記錄。n",stmt.m_cda.rpc);      // 提交事務    conn.commit();  }  

運行效果

在這裡插入圖片描述

4、查詢超女表中的記錄

示例(selecttable.cpp)

/*   *  程式名:selecttable.cpp,此程式演示freecplus框架操作MySQL資料庫(查詢表中的記錄)。   *  作者:C語言技術網(www.freecplus.net) 日期:20190525  */  #include "_mysql.h"   // freecplus框架操作MySQL的頭文件。    // 定義用於超女資訊的結構,與表中的欄位對應。  struct st_girls  {    long id;        // 超女編號,用long數據類型對應Oracle無小數的number(10)。    char name[31];  // 超女姓名,用char[31]對應Oracle的varchar2(30)。    double weight;  // 超女體重,用double數據類型對應Oracle有小數的number(8,2)。    char btime[20]; // 報名時間,用char對應Oracle的date,格式:'yyyy-mm-dd hh24:mi:ss'。  } stgirls;    int main(int argc,char *argv[])  {    connection conn; // 資料庫連接類      // 登錄資料庫,返回值:0-成功,其它-失敗。    // 失敗程式碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。    if (conn.connecttodb("172.16.0.15,root,123qweASD!@#,mysql,3306","gbk") != 0)    {      printf("connect database failed.n%sn",conn.m_cda.message); return -1;    }      sqlstatement stmt(&conn); // 操作SQL語句的對象。      int iminid,imaxid;  // 查詢條件最小和最大的id。      // 準備查詢表的SQL語句。    stmt.prepare("      select id,name,weight,date_format(btime,'%%Y-%%m-%%d %%h:%%i:%%s') from girls where id>=:1 and id<=:2");    // 也可以用以下一行程式碼代替上面這行程式碼,兼容oracle資料庫。    // select id,name,weight,to_char(btime,'yyyy-mm-dd hh24:mi:ss') from girls where id>=:1 and id<=:2");    // prepare方法不需要判斷返回值。    // 為SQL語句綁定輸入變數的地址,bindin方法不需要判斷返回值。    stmt.bindin(1,&iminid);    stmt.bindin(2,&imaxid);    // 為SQL語句綁定輸出變數的地址,bindout方法不需要判斷返回值。    stmt.bindout(1,&stgirls.id);    stmt.bindout(2, stgirls.name,30);    stmt.bindout(3,&stgirls.weight);    stmt.bindout(4, stgirls.btime,19);      iminid=2;  // 指定待查詢記錄的最小id的值。    imaxid=4;  // 指定待查詢記錄的最大id的值。      // 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。    // 失敗程式碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。    if (stmt.execute() != 0)    {      printf("stmt.execute() failed.n%sn%sn",stmt.m_sql,stmt.m_cda.message); return -1;    }      // 本程式執行的是查詢語句,執行stmt.execute()後,將會在資料庫的緩衝區中產生一個結果集。    while (1)    {      memset(&stgirls,0,sizeof(stgirls)); // 先把結構體變數初始化。        // 從結果集中獲取一條記錄,一定要判斷返回值,0-成功,1403-無記錄,其它-失敗。      // 在實際開發中,除了0和1403,其它的情況極少出現。      if (stmt.next() !=0) break;        // 把獲取到的記錄的值列印出來。      printf("id=%ld,name=%s,weight=%.02f,btime=%sn",stgirls.id,stgirls.name,stgirls.weight,stgirls.btime);    }      // 請注意,stmt.m_cda.rpc變數非常重要,它保存了SQL被執行後影響的記錄數。    printf("本次查詢了girls表%ld條記錄。n",stmt.m_cda.rpc);  }  

運行效果

在這裡插入圖片描述

5、查詢超女表中的記錄數

示例(counttable.cpp)

/*   *  程式名:counttable.cpp,此程式演示freecplus框架操作MySQL資料庫(查詢表中的記錄數)。   *  作者:C語言技術網(www.freecplus.net) 日期:20190525  */  #include "_mysql.h"   // freecplus框架操作MySQL的頭文件。    int main(int argc,char *argv[])  {    connection conn; // 資料庫連接類      // 登錄資料庫,返回值:0-成功,其它-失敗。    // 失敗程式碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。    if (conn.connecttodb("172.16.0.15,root,123qweASD!@#,mysql,3306","gbk") != 0)    {      printf("connect database failed.n%sn",conn.m_cda.message); return -1;    }      sqlstatement stmt(&conn); // 操作SQL語句的對象。      int icount=0;  // 用於存放查詢結果的記錄數。      // 準備查詢表的SQL語句,把查詢條件直接寫在SQL語句中,沒有採用綁定輸入變數的方法。    stmt.prepare("select count(*) from girls where id>=2 and id<=4");    // prepare方法不需要判斷返回值。    // 為SQL語句綁定輸出變數的地址,bindout方法不需要判斷返回值。    stmt.bindout(1,&icount);      // 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。    // 失敗程式碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。    if (stmt.execute() != 0)    {      printf("stmt.execute() failed.n%sn%sn",stmt.m_sql,stmt.m_cda.message); return -1;    }      // 本程式執行的是查詢語句,執行stmt.execute()後,將會在資料庫的緩衝區中產生一個結果集。    // 但是,在本程式中,結果集永遠只有一條記錄,調用stmt.next()一次就行,不需要循環。    stmt.next();      printf("girls表中符合條件的記錄數是%d。n",icount);  }  

運行效果

在這裡插入圖片描述

7、刪除超女表中的記錄

示例(deletetable.cpp)

/*   *  程式名:deletetable.cpp,此程式演示freecplus框架操作MySQL資料庫(刪除表中的記錄)。   *  作者:C語言技術網(www.freecplus.net) 日期:20190525  */  #include "_mysql.h"   // freecplus框架操作MySQL的頭文件。    int main(int argc,char *argv[])  {    connection conn; // 資料庫連接池。      // 登錄資料庫,返回值:0-成功,其它-失敗。    // 失敗程式碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。    if (conn.connecttodb("172.16.0.15,root,123qweASD!@#,mysql,3306","gbk") != 0)    {      printf("connect database failed.n%sn",conn.m_cda.message); return -1;    }      sqlstatement stmt(&conn); // 操作SQL語句的對象。      // 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。    // 失敗程式碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。    // 如果不需要綁定輸入和輸出變數,用stmt.execute()方法直接執行SQL語句,不需要stmt.prepare()。    if (stmt.execute("delete from girls where id>=2 and id<=4") != 0)    {      printf("stmt.execute() failed.n%sn%sn",stmt.m_sql,stmt.m_cda.message); return -1;    }      // 請注意,stmt.m_cda.rpc變數非常重要,它保存了SQL被執行後影響的記錄數。    printf("本次從girls表中刪除了%ld條記錄。n",stmt.m_cda.rpc);      // 提交事務    conn.commit();  }  

運行效果

在這裡插入圖片描述

8、與Oracle的兼容性處理

在封裝sqlstatement類的時候,為了與Oracle兼容,做了以下方面的處理:

1)在MySQL中,綁定輸入和輸出變數採用的是"?",Oracle採用的是":n"(n表示變數的序號),在sqlstatement的prepare方法中,把":n"替換成了"?"。

2)在MySQL中,字元串與日期的轉換函數是str_to_date和date_format,Oracle的轉換函數是to_date和to_char,在sqlstatement的prepare方法中,把to_date替換成str_to_date,把to_char替換成date_format。

3)MySQL有時間格式是"%Y-%m-%d %h:%i:%s",Oracle資料庫是"yyyy-mm-dd hh24:mi:ss",在sqlstatement的prepare方法中,把"yyyy-mm-dd hh24:mi:ss"替換成"%Y-%m-%d %h:%i:%s"。目前,只對"%Y-%m-%d %h:%i:%s"和"%Y%m%d%h%i%s"兩個格式做了替換,如果需要對更多的格式做替換,請修改sqlstatement的prepare方法中的源程式碼。

4)MySQL的sqlstatement類綁定輸入或輸出變數的最大數量預設是256,在"_mysql.h"頭文件中定義了MAXPARAMS宏,您可以根據實際需求修改它。

// 執行SQL語句前綁定輸入或輸出變數個數的最大值,256是很大的了,可以根據實際情況調整。  #define MAXPARAMS  256  

9、longtext和longblob欄位的操作

MySQL提供的庫函數支援對longtext和longblob欄位的操作,本人的技術水平有限,找不到這方面的資料和示常式序,所以還沒有封裝對longtext和longblob欄位的操作,希望各位能提供技術幫助,通過C語言技術網與我聯繫,我們共同完善freecplus框架,非常感謝。

七、應用經驗

本文提供的示常式序看上去簡單,實則很精妙,希望大家多多思考,慢慢體會。

為了讓大家完全掌握connection和sqlstatement類的用法,我將錄製freecplus框架的專題影片,請大家多關注C語言技術網(www.freecplus.net)發布的內容。

八、版權聲明

C語言技術網原創文章,轉載請說明文章的來源、作者和原文的鏈接。
來源:C語言技術網(www.freecplus.net)
作者:碼農有道