青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

兔子的技術博客

兔子

   :: 首頁 :: 聯系 :: 聚合  :: 管理
  202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

留言簿(10)

最新評論

閱讀排行榜

評論排行榜


一、在你的程序中使用數據庫是不錯的注意。如果已經有可用的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直到它返回一個空指針以得到查詢中的每一行。   
        注意在這個例子里,我們沒有檢查有空指針的列。如果你不使用非空列的表,那么你必須檢查一個特殊行的列是否為空。一旦你使用完畢一個結果集,你必須釋放它。這通過   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;

轉自:http://blog.csdn.net/ztj111/article/details/2512147
posted on 2012-03-13 18:00 會飛的兔子 閱讀(1282) 評論(0)  編輯 收藏 引用 所屬分類: C++庫,組件數據庫,MIS系統
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            老鸭窝91久久精品色噜噜导演| 亚洲一级高清| 麻豆乱码国产一区二区三区| 久久成人亚洲| 久久天堂精品| 欧美jizz19hd性欧美| 欧美大片18| 欧美性猛交视频| 国产无一区二区| 1024成人| 亚洲一区二区三区在线| 欧美一区二区高清| 欧美a级大片| 夜夜嗨av一区二区三区网页| 午夜精品福利一区二区蜜股av| 久久成人国产精品| 欧美激情一二区| 国产精品天美传媒入口| 亚洲激情欧美激情| 欧美在线国产精品| 亚洲国产日韩美| 中文日韩在线| 久久免费偷拍视频| 国产精品天天看| 99精品福利视频| 久久免费国产精品| 国产精品视频精品视频| 欧美一区91| 毛片av中文字幕一区二区| 欧美手机在线| 亚洲第一视频| 欧美在线免费一级片| 亚洲国内精品| 久久精品国产清自在天天线| 欧美日韩专区在线| 亚洲日本欧美在线| 另类亚洲自拍| 欧美一二三区精品| 国产精品久久久久久久9999| 亚洲麻豆一区| 欧美成人免费全部| 欧美一区二区精品在线| 国产精品久久婷婷六月丁香| 亚洲日本成人网| 另类酷文…触手系列精品集v1小说| 亚洲天堂成人在线观看| 欧美久久久久| 亚洲美女在线视频| 欧美激情欧美狂野欧美精品| 久久精品国产亚洲aⅴ| 国产伦精品一区二区三区免费迷 | 亚洲素人一区二区| 欧美激情va永久在线播放| 新67194成人永久网站| 国产精品视频xxx| 亚洲自拍电影| 日韩一级裸体免费视频| 欧美激情第8页| 亚洲免费高清| 亚洲美女精品成人在线视频| 欧美成人日本| 99视频一区| a4yy欧美一区二区三区| 欧美调教视频| 亚洲欧美中日韩| 亚洲欧美日韩国产综合精品二区| 国产精品一区亚洲| 久久精品五月| 久久中文精品| 亚洲私人影吧| 午夜精品久久久久久久男人的天堂 | 欧美a级片网站| 久久夜色撩人精品| 亚洲精品久久久久中文字幕欢迎你 | 国产日韩欧美在线看| 久久精品国产欧美激情| 久久精品道一区二区三区| 亚洲破处大片| 99国产精品久久久| 国产精品家教| 久久精品一区| 欧美成人一区在线| 亚洲一区二区影院| 久久成人精品电影| 亚洲人精品午夜| 亚洲一区二区三区在线观看视频| 国产一区清纯| 亚洲国产三级在线| 国产精品亚洲一区二区三区在线| 久久午夜电影| 欧美日韩在线精品| 久久综合狠狠综合久久综青草| 美女任你摸久久| 午夜精品福利在线| 美女日韩在线中文字幕| 亚洲欧美激情视频在线观看一区二区三区| 香蕉久久夜色精品国产使用方法| 亚洲国产专区校园欧美| 亚洲欧美一区二区原创| 亚洲卡通欧美制服中文| 午夜亚洲性色福利视频| 99精品欧美一区二区三区综合在线| 亚洲一区二区在线看| 最新亚洲一区| 欧美中文在线观看| 亚洲愉拍自拍另类高清精品| 蜜臀a∨国产成人精品| 午夜在线精品| 欧美日韩国产bt| 欧美激情一区二区三区在线视频观看 | 欧美大片在线看| 欧美在线观看你懂的| 欧美另类人妖| 欧美激情亚洲精品| 黄色成人av在线| 亚洲欧美日韩国产成人精品影院| av不卡在线观看| 久久综合九色综合欧美就去吻| 性久久久久久久| 欧美午夜精品| 亚洲人体一区| 99re66热这里只有精品3直播| 久久久视频精品| 久久久精品免费视频| 国产精品久久久久久久久借妻| 亚洲国产高清一区二区三区| 在线观看日韩欧美| 久久精品一级爱片| 久久精品一区二区三区中文字幕| 国产精品国产一区二区| 亚洲精品在线一区二区| 亚洲精品色婷婷福利天堂| 卡通动漫国产精品| 亚洲丶国产丶欧美一区二区三区| 一区二区视频免费在线观看| 久久精品中文字幕免费mv| 久久艳片www.17c.com| 一区二区三区不卡视频在线观看| 免费视频久久| 久久人91精品久久久久久不卡| 国产精品久久久久免费a∨大胸 | 欧美1区2区| 在线观看成人网| 久久亚洲影院| 亚洲国产一区二区三区在线播| 亚洲毛片av| 欧美日韩一区二区视频在线观看| 亚洲精品在线免费| 亚洲欧美日韩在线观看a三区| 欧美视频第二页| 亚洲一区国产| 久久久久久夜| 亚洲日韩中文字幕在线播放| 欧美人体xx| 亚洲欧美日韩一区二区在线| 久久―日本道色综合久久| 亚洲国产精品久久| 欧美日韩成人一区二区| 中文亚洲视频在线| 裸体一区二区三区| 日韩天堂av| 国产欧美日韩亚洲精品| 久久尤物电影视频在线观看| 亚洲破处大片| 久久精品日韩一区二区三区| 国外成人在线视频| 欧美日韩国产电影| 午夜一区二区三区在线观看| 女同一区二区| 亚洲影院免费| 在线激情影院一区| 国产精品毛片大码女人| 久久精品国产999大香线蕉| 亚洲国产天堂久久综合网| 亚洲欧美在线高清| 亚洲韩日在线| 国产欧美日韩综合| 欧美激情亚洲| 欧美一区二区三区免费视| 亚洲激情中文1区| 久久久久久综合网天天| 亚洲婷婷国产精品电影人久久| 国产亚洲免费的视频看| 欧美激情亚洲激情| 久久久久国色av免费观看性色| av成人免费在线| 欧美激情在线免费观看| 久久精品盗摄| 午夜精品一区二区三区电影天堂| 亚洲激精日韩激精欧美精品| 国产欧美日韩另类视频免费观看| 欧美激情精品| 久久久97精品| 午夜日韩福利| 亚洲色图自拍| 在线亚洲免费视频| 日韩亚洲欧美高清| 亚洲人成网站精品片在线观看| 麻豆成人精品| 麻豆九一精品爱看视频在线观看免费 |