兔子的技术博客

兔子

   :: 首页 :: 联系 :: 聚合  :: 管理
  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 会飞的兔子 阅读(1214) 评论(0)  编辑 收藏 引用 所属分类: C++库,组件数据库,MIS系统

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理