日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線(xiàn)溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
用C語(yǔ)言如何對(duì)MySQL數(shù)據(jù)庫(kù)進(jìn)行操作

我們大家都知道用C語(yǔ)言對(duì)MySQL數(shù)據(jù)庫(kù)進(jìn)行操作可以說(shuō)是一件很麻煩的事情,我們要進(jìn)行連接、插入以及修改與刪除等相關(guān)的操作,當(dāng)然也有很多人會(huì)用MySQL數(shù)據(jù)庫(kù)來(lái)開(kāi)發(fā)一些項(xiàng)目。

有時(shí)為了性能,我們會(huì)直接用C語(yǔ)言來(lái)開(kāi)發(fā)相關(guān)的模塊,尤其在我們的web應(yīng)用中,雖然PHP、JSP等腳本均提供了MySQL的接口,但是顯然直接使用C語(yǔ)言具有更好的安全性和性能,Michael以前用PHP開(kāi)發(fā)的多個(gè)項(xiàng)目中就使用了C語(yǔ)言編寫(xiě)的這類(lèi)接口,然后再編譯到php里面,供php腳本直接使用,這方面的話(huà)題就不多說(shuō)了,下面主要說(shuō)一下在Linux下如何用C語(yǔ)言連接MySQL數(shù)據(jù)庫(kù),并且讀取里面的數(shù)據(jù)返回,同時(shí)如何進(jìn)行編譯。

這里的大部分代碼參考了MySQL發(fā)行包里面的.c源文件,大家也可以去里面找找相關(guān)的代碼,下面這段代碼實(shí)現(xiàn)了連接到本地MySQL服務(wù)器上9tmd_bbs_utf8數(shù)據(jù)庫(kù),從數(shù)據(jù)表tbb_user中根據(jù)輸入的userid取得該用戶(hù)的用戶(hù)名并打印輸出到終端。

if defined(_WIN32) || defined(_WIN64)為了支持windows平臺(tái)上的編譯

 
 
 
  1. #include  
  2. #endif  
  3. #include  
  4. #include  
  5. #include "mysql.h" 

我的機(jī)器上該文件在/usr/local/include/mysql下

定義MySQL數(shù)據(jù)庫(kù)操作的宏,也可以不定義留著后面直接寫(xiě)進(jìn)代碼

 
 
 
  1. define SELECT_QUERY "select username from tbb_user where userid = %d"  
  2. int main(int argc, char **argv)char **argv 相當(dāng)于 char *argv[]  
  3. {  

MYSQL mysql,*sock;定義數(shù)據(jù)庫(kù)連接的句柄,它被用于幾乎所有的MySQL函數(shù)

MYSQL_RES *res;查詢(xún)結(jié)果集,結(jié)構(gòu)類(lèi)型

MYSQL_FIELD *fd ;包含字段信息的結(jié)構(gòu)

MYSQL_ROW row ;存放一行查詢(xún)結(jié)果的字符串?dāng)?shù)組

char qbuf[160];存放查詢(xún)sql語(yǔ)句字符串

 
 
 
  1. if (argc != 2) { //檢查輸入?yún)?shù)  
  2. fprintf(stderr,"usage : mysql_select \n\n");  
  3. exit(1);  
  4. }  
  5. mysql_init(&mysql);  
  6. if (!(sock = mysql_real_connect(&mysql,"localhost","dbuser","dbpwd","9tmd_bbs_utf8",0,NULL,0))) {  
  7. fprintf(stderr,"Couldn't connect to engine!\n%s\n\n",mysql_error(&mysql));  
  8. perror("");  
  9. exit(1);  
  10. }  
  11. sprintf(qbuf,SELECT_QUERY,atoi(argv[1]));  
  12. if(mysql_query(sock,qbuf)) {  
  13. fprintf(stderr,"Query failed (%s)\n",mysql_error(sock));  
  14. exit(1);  
  15. }  
  16. if (!(res=mysql_store_result(sock))) {  
  17. fprintf(stderr,"Couldn't get result from %s\n", mysql_error(sock));  
  18. exit(1);  
  19. }  
  20. printf("number of fields returned: %d\n",mysql_num_fields(res));  
  21. while (row = mysql_fetch_row(res)) {  
  22. printf("Ther userid #%d 's username is: %s\n", atoi(argv[1]),(((row[0]==NULL)&&(!strlen(row[0]))) ? "NULL" : row[0])) ;   
  23. puts( "query ok !\n" ) ;   
  24. }   
  25. mysql_free_result(res);  
  26. mysql_close(sock);  
  27. exit(0);  
  28. return 0;  

為了兼容大部分的編譯器加入此行
}
編譯的時(shí)候,使用下面的命令

gcc -o mysql_select ./mysql_select.c -I/usr/local/include/mysql -L/usr/local/lib/mysql -lmysqlclient (-lz) (-lm) 后面兩個(gè)選項(xiàng)可選,根據(jù)您的環(huán)境情況運(yùn)行的時(shí)候,執(zhí)行下面的命令

./mysql_select 1

將返回如下結(jié)果:

 
 
 
  1. number of fields returned: 1  
  2. Ther userid #1 's username is: Michael  
  3. query ok ! 

上面的代碼我想大部分都能看明白,不明白的可以參考一下MySQL提供的有關(guān)C語(yǔ)言API部分文檔,各個(gè)函數(shù)都有詳細(xì)說(shuō)明,有時(shí)間我整理一份常用的API說(shuō)明出來(lái)。

以上的相關(guān)內(nèi)容就是對(duì)用C語(yǔ)言操作MySQL數(shù)據(jù)庫(kù)的介紹,望你能有所收獲。


標(biāo)題名稱(chēng):用C語(yǔ)言如何對(duì)MySQL數(shù)據(jù)庫(kù)進(jìn)行操作
當(dāng)前網(wǎng)址:http://www.dlmjj.cn/article/djcceod.html