我們大家都知道用C語言對MySQL數據庫進行操作可以說是一件很麻煩的事情,我們要進行連接、插入以及修改與刪除等相關的操作,當然也有很多人會用MySQL數據庫來開發一些項目。
有時為了性能,我們會直接用C語言來開發相關的模塊,尤其在我們的web應用中,雖然PHP、JSP等腳本均提供了MySQL的接口,但是顯然直接使用C語言具有更好的安全性和性能,Michael以前用PHP開發的多個項目中就使用了C語言編寫的這類接口,然後再編譯到php裡面,供php腳本直接使用,這方面的話題就不多說了,下面主要說一下在Linux下如何用C語言連接MySQL數據庫,並且讀取裡面的數據返回,同時如何進行編譯。
這裡的大部分代碼參考了MySQL發行包裡面的.c源文件,大家也可以去裡面找找相關的代碼,下面這段代碼實現了連接到本地MySQL服務器上9tmd_bbs_utf8數據庫,從數據表tbb_user中根據輸入的userid取得該用戶的用戶名並打印輸出到終端。
if defined(_WIN32) || defined(_WIN64)為了支持windows平台上的編譯
- #include <windows.h>
- #endif
- #include <stdio.h>
- #include <stdlib.h>
- #include "mysql.h"
我的機器上該文件在/usr/local/include/mysql下
定義MySQL數據庫操作的宏,也可以不定義留著後面直接寫進代碼
- define SELECT_QUERY "select username from tbb_user where userid = %d"
- int main(int argc, char **argv)char **argv 相當於 char *argv[]
- {
MYSQL mysql,*sock;定義數據庫連接的句柄,它被用於幾乎所有的MySQL函數
MYSQL_RES *res;查詢結果集,結構類型
MYSQL_FIELD *fd ;包含字段信息的結構
MYSQL_ROW row ;存放一行查詢結果的字符串數組
char qbuf[160];存放查詢sql語句字符串
- if (argc != 2) { //檢查輸入參數
- fprintf(stderr,"usage : mysql_select <userid>\n\n");
- exit(1);
- }
- mysql_init(&mysql);
- if (!(sock = mysql_real_connect(&mysql,"localhost","dbuser","dbpwd","9tmd_bbs_utf8",0,NULL,0))) {
- fprintf(stderr,"Couldn't connect to engine!\n%s\n\n",mysql_error(&mysql));
- perror("");
- exit(1);
- }
- sprintf(qbuf,SELECT_QUERY,atoi(argv[1]));
- if(mysql_query(sock,qbuf)) {
- fprintf(stderr,"Query failed (%s)\n",mysql_error(sock));
- exit(1);
- }
- if (!(res=mysql_store_result(sock))) {
- fprintf(stderr,"Couldn't get result from %s\n", mysql_error(sock));
- exit(1);
- }
- printf("number of fields returned: %d\n",mysql_num_fields(res));
- while (row = mysql_fetch_row(res)) {
- printf("Ther userid #%d 's username is: %s\n", atoi(argv[1]),(((row[0]==NULL)&&(!strlen(row[0]))) ? "NULL" : row[0])) ;
- puts( "query ok !\n" ) ;
- }
- mysql_free_result(res);
- mysql_close(sock);
- exit(0);
- return 0;
為了兼容大部分的編譯器加入此行
}
編譯的時候,使用下面的命令
gcc -o mysql_select ./mysql_select.c -I/usr/local/include/mysql -L/usr/local/lib/mysql -lmysqlclient (-lz) (-lm) 後面兩個選項可選,根據您的環境情況運行的時候,執行下面的命令
./mysql_select 1
將返回如下結果:
- number of fields returned: 1
- Ther userid #1 's username is: Michael
- query ok !
上面的代碼我想大部分都能看明白,不明白的可以參考一下MySQL提供的有關C語言API部分文檔,各個函數都有詳細說明,有時間我整理一份常用的API說明出來。
以上的相關內容就是對用C語言操作MySQL數據庫的介紹,望你能有所收獲。