C語言對mysql資料庫的操作

來源:互聯網
上載者:User

標籤:blog   http   io   ar   os   使用   sp   for   on   

原文:C語言對mysql資料庫的操作

這已經是一相當老的話題。不過今天我才首次使用,把今天的一些體會寫下來,也許能給一些新手帶來一定的協助,更重要的是供自己今後忘記的怎麼使用而進行查閱的!我們言歸正傳1.標頭檔:       #include <stdio.h>        #include <stdlib.h>       #include <mysql/mysql.h> //這個是必需要包含的,下面對mysql的所有操作函數,都出自這裡2.定義一個MYSQL變數:       MYSQL mysql;       這裡MYSQL是一個用於串連MySql資料庫的變數。       在後面對mysql資料庫的操作中,我們就用這個MYSQL變數作為控制代碼的。3.定義資料庫參數:       char host[32]=”localhost”;  
       char user[32]=”username”;  
       char passwd[32]=”pwd”; 
       char dbname[32]=”testdb”; 4.資料庫操作       1).初始化資料庫:
        mysql_init(&mysql);
       2).串連資料庫:
           mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0);
         我們在操作時,可以對以上的函數進行if測試,如果初始化或者串連出錯,作出相應提示,以便調試。
5.對資料庫的操作:
         Mysql_query(&mysql, “select * from testdb where condition”);
         我們在實際操作中,為了更方便的使用程式中的某些變數,我們將會用到一個函數:
         int sprintf(char *str, const char *format, …);
         這個函數用來格式化我們的字串,然後將變數按照給你的格式,賦給第一個參數。
         我們使用這個方法方法可以很方便的使用我們的變數來對資料庫進行操作。例如我們將要進行資料庫的查詢操作,我們就可以這樣使用:
         sprintf(sql,”select * from testdb where username = ‘%s’”, u_name);
         然後使用mysql_query(&mysql, sql)進行查詢。
        
        其實大家已經注意到了,在sprintf函數中第二個參數是我們非常熟悉的sql語句,只不過在條件的右端使用了類似輸出函數的格式符,因為我們使用了變數。當然,在沒有變數的時候,我們可以省去第三個參數,但是這樣,我們使用sprintf的作用也就隨之消失了。 
        大家對sql語句的操作一定比我更加熟悉,因此,關於刪除和修改的例子我們就不過列舉了。
6.關閉資料庫連接:        
     Mysql_close(&mysql);                  也許大夥都使用過php對mysql進行操作。也許也已經發現,在c語言中,對mysql資料庫的操作和php有很大的相似之處。下面我賦上一段小小的代碼,來結束這篇文檔!:)希望大家給予指點。#include <stdio.h>
#include <mysql/mysql.h>
#include <stdlib.h>
#include <errno.h>
#include <syslog.h>
MYSQL mysql;
main(){   
         char host[32]=”localhost”; // mysql host
         char user[32]=”username”;//mysql user name
         char passwd[32]="pwd";        //mysql pwd
         char dbname[32]=”testdb”;//mysql db
         
         
          
       if( mysql_init(&mysql) == NULL )
         {  
                 syslog(LOG_USER|LOG_INFO,”inital mysql handle error\n”);
                  return 1; 
        }
         if (mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0) == NULL)
         {
                   syslog(LOG_USER|LOG_INFO, “Failed to connect to database: Error: %s\n”,mysql_error(&mysql));
                  return 1; 
        }
        else syslog(LOG_USER|LOG_INFO, “connect to database: \n”);
        printf(”connected to the db!\n”); 
        int a = find_ps(); 
        printf(”the num is:%d\n”,a); 
        db_close(); 
        return 0;}int db_close(){
        mysql_close(&mysql);
        return 0;
       }
      int  find_ps (){
         MYSQL_ROW m_row;
         MYSQL_RES *m_res;
         char sql[1024],username[32];
         int res=1;
         int *id;          sprintf(sql,”select * from testdb where user_name = ‘%s’”, u_name);
         if(mysql_query(&mysql,sql) != 0)
         {
                   syslog(LOG_USER|LOG_INFO, “select ps_info Error: %s\n”,mysql_error(&mysql));       
                   return res;        
         }        
         m_res = mysql_store_result(&mysql);
         if(m_res==NULL)
         {
                   syslog(LOG_USER|LOG_INFO, “select username Error: %s\n”,mysql_error(&mysql)); 
                   res = 3;
                   return res;
         }
         }
         mysql_free_result(m_res);
         return res;} 7.編譯:       別忘了加上庫位置,否則編譯無法通過!       gcc  -L/usr/lib/mysql –lmysqlclient func.c -o func     呵呵,別忘記哦!

C語言對mysql資料庫的操作

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.