自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

用C語言如何對MySQL數據庫進行操作

數據庫 MySQL
以下的文章主要介紹的是如何正確運用C語言來對MySQL數據庫進行操作,同時文章也包括了其實際操作過程中的相關代碼的描述。

我們大家都知道用C語言對MySQL數據庫進行操作可以說是一件很麻煩的事情,我們要進行連接、插入以及修改與刪除等相關的操作,當然也有很多人會用MySQL數據庫來開發(fā)一些項目。

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

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

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

  1. #include <windows.h> 
  2. #endif  
  3. #include <stdio.h> 
  4. #include <stdlib.h> 
  5. #include "mysql.h" 

我的機器上該文件在/usr/local/include/mysql下

定義MySQL數據庫操作的宏,也可以不定義留著后面直接寫進代碼

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

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

MYSQL_RES *res;查詢結果集,結構類型

MYSQL_FIELD *fd ;包含字段信息的結構

MYSQL_ROW row ;存放一行查詢結果的字符串數組

char qbuf[160];存放查詢sql語句字符串

  1. if (argc != 2) { //檢查輸入參數  
  2. fprintf(stderr,"usage : mysql_select <userid>\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;  

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

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

./mysql_select 1

將返回如下結果:

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

上面的代碼我想大部分都能看明白,不明白的可以參考一下MySQL提供的有關C語言API部分文檔,各個函數都有詳細說明,有時間我整理一份常用的API說明出來。

以上的相關內容就是對用C語言操作MySQL數據庫的介紹,望你能有所收獲。

【編輯推薦】

  1. MySQL兩項性能的基本測試淺談
  2. MySQL 連接池的實際配置問題
  3. Mysql臨時表的具體使用方案
  4. 用Excel如何對MySQL數據進行分析
  5. MySQL數據類型與相應的建庫策略
     

 

責任編輯:佚名 來源: 博客園
相關推薦

2009-02-02 16:50:34

數據庫表的鎖定MySQL

2018-02-26 20:00:00

編程語言JavaMySQL

2010-07-02 14:46:20

SQL Server數

2009-02-02 17:21:58

日志文件維護MySQL日志文件

2010-06-12 15:53:22

MySQL數據庫

2010-05-28 16:04:03

讀取MySQL數據庫

2010-06-01 16:35:43

MySQL數據庫

2010-05-17 16:25:05

MySQL數據

2010-02-04 17:42:15

Android數據庫

2018-05-10 17:18:59

數據庫MySQL密碼

2010-06-01 12:51:23

MySQL數據庫

2019-02-28 21:20:50

MySQL備份與恢復數據庫

2010-05-26 11:21:00

MySQL數據庫操作

2011-04-14 09:05:07

ExcelMySQL數據

2010-06-01 17:56:27

存入MySQL數據庫

2010-05-31 18:24:53

MySQL數據庫

2010-05-14 11:12:16

連接MySql

2010-02-02 15:48:49

Python數據庫

2010-02-02 17:27:16

C++連接MySqL數

2011-04-26 10:24:27

C++MySQL
點贊
收藏

51CTO技術棧公眾號