VC的MySQL編程

來源:互聯網
上載者:User

一、在你的程式中使用資料庫是不錯的注意。如果已經有可用的MySQL伺服器,在VC中可以按照如下方法實現與資料庫的串連。
1、找來MySQL(Win32)安裝目錄下的include檔案夾,將其添加到VC標頭檔目錄列表中;
(VC6 -> Options -> Directories -> 加入此目錄)
(VC2005
-> 工具 -> 選擇 ->項目和解決方案 -> VC++目錄 -> 顯示以下內容的目錄 -> 包含檔案
-> 加入此目錄)2、找來MySQL(Win32)安裝目錄下的lib檔案夾,將 其添加到VC庫檔案目錄列表中;
(VC6 -> Options -> Directories -> 加入此目錄)
(VC2005 -> 工具 ->選擇 -> 項目和解決方案 -> VC++目錄 -> 顯示以下內容的目錄 -> 庫檔案 -> 加入此目錄,注意是lib\debug或lib\opt)
3、建立一個工程,參考如下代碼:
// mysql.cpp : Defines the entry point for the console application.

#include "stdafx.h"
#include <stdio.h>
#include <winsock.h>
#include <mysql.h>
#include <windows.h>
#pragma comment(lib, "libmysql.lib")
int main(int argc, char* argv[])
{
    unsigned short Port = 3306;
    char *IPAddress = "192.168.31.56";
    char *UserName = "root";
    char *Password = "";
    char *DBName = "SAS_1_2_0";
    printf("Start... ");
 
    MYSQL *ssock;
    //char execsql[500];
    ssock = (MYSQL *)malloc(sizeof(MYSQL));   
    //在某些版本中,不需要該初始化工作,可觀看mysql.H以及readme
    mysql_init(ssock);
    if(ssock == NULL)
    {
        printf("EROR: MySQL ssock init error. ");
        return FALSE;
    }

    //串連到指定的資料庫
    ssock = mysql_real_connect(ssock, IPAddress, UserName, Password, NULL, Port, NULL, 0);
    if(!ssock)
    {
        printf("conn fail... ");
        //memcpy(eee, mysql_error(ssock), 20);
        //fprintf(stderr, "Failed to connect to database: Error: %s ", mysql_error(ssock));
       
        //printf("%c ", eee);
        unsigned int mtint = mysql_errno(ssock);
        //printf("%d ");
        return FALSE;
    }
    if(mysql_select_db(ssock, DBName) != 0)
    {
        printf("select db error. ");
        return FALSE;
    }
    printf("version=%d ", mysql_get_server_version(ssock));
    //exec my execsql string
    //sprintf(execsql,"create table girls (name char(10),age int)");
    //mysql_real_query(ssock,execsql,strlen(execsql));
    mysql_close(ssock);
    printf("End... ");
    return TRUE;

二、怎樣用c/c++編程串連mysql資料庫
     執行一個查詢有以下幾個步驟要做。首先執行一個查詢,然後儲存結果,  
     得到的是一個子集。這裡是一個小例子:  
  #include   <stdio.h>  
  #include    
  #include   <mysql.h>
  MYSQL   mysql;  
  MYSQL_RES   *res;  
  MYSQL_ROW   row;  
  void   exiterr(int   exitcode)  
  {  
       fprintf(   stderr,   "%s\n",   mysql_error(&mysql)   );  
       exit(   exitcode   );  
  }  
  int   main()  
  {  
        uint   i   =   0;  
        if   (!(mysql_connect(&mysql,"host","username","password")))    
                 exiterr(1);   
        if   (mysql_select_db(&mysql,"payroll"))  
              exiterr(2);   
        if   (mysql_query(&mysql,"SELECT   name,rate   FROM   emp_master"))  
              exiterr(3);  
        if   (!(res   =   mysql_store_result(&mysql)))  
              exiterr(4);   
        while((row   =   mysql_fetch_row(res)))   {  
             for   (i=0   ;   i   <   mysql_num_fields(res);   i++)    
                  printf("%s\n",row[i]);   
        }  
        mysql_free_result(res);  
        mysql_close(&mysql);  
   }  
        mysql_query   函數將把查詢送給伺服器,如果查詢成功,調用mysql_store_result 函數將分配一個MYSQL_RES   結構並且重新從伺服器獲得一個結果集。
       你可以用mysql_fetch_row   函數來查看資料。這樣做你將獲得一個   MYSQL_ROW   指標指向資料中的一行。   MYSQL_ROW   指標是一簡單的字串數組。所有的資料類型被轉換成字串送到用戶端。  
        mysql_num_fields函數將告訴你返回的列數。你可以繼續調用mysql_fetch_row直到它返回一個null 指標以得到查詢中的每一行。  
        注意在這個例子裡,我們沒有檢查有null 指標的列。如果你不使用非空列的表,那麼你必須檢查一個特殊行的列是否為空白。一旦你使用完畢一個結果集,你必須釋放它。這通過   mysql_free_result   來完成。  
       最後調用mysql_close來關閉你和資料庫之間的串連。  
       查看結果集你可以不用調用mysql_fetch_row就查出返回的結果集共有多少行。這由
      int   mysql_num_rows(MYSQL_RES   *result)來完成。  
      
改變到被下一個   mysql_fetch_row   調用返回的行,你可以用void  
mysql_data_seek(MYSQL_RES   *res,   uint   offset)   改變到任意一行。  獲得更多的資訊
你可以使用這幾個額外的函數來找出關於一個查詢的更多的資訊,並從伺服器獲得這些資訊。  
        如果你執行一個UPDATE,   INSERT   或者   DELETE   查詢,你可以用int   mysql_affected_rows   來查出共有多少行資料被你影響到。  
       如果在你的資料庫裡有位元據,那麼得知資料的長度將是有用的。unsigned  int   *mysql_fetch_lengths(MYSQL_RES   *mysql)   將返回一指出了結果集中每一列 的長度的整型數組。  
      當你插入一個帶有   AUTO_INCREMENT   列的表的時候,你可以用int   mysql_insert_id(MYSQL   *mysql)   來查出產生的那一行的ID。  
======================

int main()
{
    MYSQL mysql;
    MYSQL_RES * res ;
    MYSQL_FIELD * fd ;
    MYSQL_ROW row ;
    int id[10000];
    double result[10000][8];
    vector<string> v;

    if(mysql_init(&mysql) == NULL)
    {
     std::cout<<"init mysql data status fail"<<std::endl;
       return false;
   } 
 else
 {
  std::cout<<"init mysql data status success"<<std::endl;
 }
 
 if(NULL == mysql_real_connect(&mysql,"localhost","root","","wsnss",MYSQL_PORT,NULL,0))
 {
  std::cout<<"connect database fail"<<std::endl<<mysql_error(&mysql)<<std::endl;;
  return false;
 }
 else{
  std::cout<<"connect database success"<<std::endl;
 }

 char   szSqlText[500]="";
 int j = 0;

 sprintf(szSqlText,"%s","select * from data_receive ");
 if (mysql_query( &mysql, szSqlText))
 //進行資料檢索
 {
     //執行SQL語句出錯
  cout<<"query error"<<endl;
  mysql_close( &mysql ) ;
  return FALSE ;
 }
    else
    {
  res = mysql_store_result( &mysql ) ;
  int i;   
  while((row   =   mysql_fetch_row(res)))   { 
   id[j] = atoi(row[0]);
    for   (i = 1; i < mysql_num_fields(res); i++)  
    {
     result[j][i-1] =  atof(row[i]);
    }
    j++;
  }
    }  
  
  
 for(int i = 0 ; i < 10000; i++)
 {
  if(i>=j)
   break;
  char str[10000];
  stringstream ss;

        ss<<"insert into
data_receive(ID,data1,data2,data3, data4,data5,data6,data7,data8)values('"<<id[i]<<"','"<<
   result[i][0]<<"','"<<result[i][1]<<"','"<<result[i][2]<<"','"<<
   result[i][3]<<"','"<<result[i][4]<<"','"<<result[i][5]<<"','"<<
   result[i][6]<<"','"<<result[i][7]<<"');";
  string s = ss.str();
  v.push_back(s);  
 }
 for(vector<string>::iterator iter = v.begin();  iter != v.end(); ++iter)
 {
  
  if(mysql_query(&mysql,(*iter).c_str())!=0)
  {
   std::cout<<"execute insert syntax fail"<<
     std::endl<<mysql_error(&mysql)<<endl;
   mysql_close(&mysql);
   return 1;
  }
 }
    mysql_free_result(res);
    mysql_close(&mysql);
    return 0;
}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.