VC的MySQL编程

一、在你的程序中使用数据库是不错的注意。如果已经有可用的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://www.mzph.cn/news/434850.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python免费学校_清华大学,的python学习路线,免费分享给小白福利

python应该是近几年比较火的语言之一&#xff0c;很多人刚学python不知道该如何学习&#xff0c;尤其是没有编程基础想要从事程序员工作的小白&#xff0c;想必应该都会有此疑惑&#xff0c;包括我刚学python的时候也是通过从网上查找相关资料以及从学校课程学习才确定python学…

mapgis转shp左右位置偏差

问题描述 问题原因 一般情况下&#xff0c;投影中心经度不会出现这么复杂的数字&#xff0c;一般都是1110000&#xff0c;1170000&#xff0c;前3个数字为整数后四个数字为0 问题解决 主要思想&#xff1a;通常相差的经纬度&#xff0c;调整投影中心点经度 解决步骤 1.试图…

Oracle Database Appliance

转载&#xff1a;http://www.hellodb.net/2011/09/oracle-database-appliance.html自从Oracle收购了SUN&#xff0c;不仅仅得到了MySQL&#xff0c;Java&#xff0c;Solaris等&#xff0c;还得到了SUN的硬件产品&#xff0c;真正成为了一家软硬通杀的服务提供商。这几年&#x…

arcgis中的插值分析了解

1.前言 打开arcgis工具箱我们可以发现arcgis为我们提供了多种插值分析的工具&#xff0c;克里金插值、反距离权重插值、样条函数插值等&#xff0c;具体如图所示 在工具箱中除地形转栅格和通过文件实现地形转栅格是用来绘制dem数据&#xff0c;其他就是我们日常研究所用的插值工…

gcovr 安装_Kudu 1.8.0 编译安装配置

安装环境&#xff1a;CentOS6.8*3解决系统依赖&#xff1a;yum install autoconf automake cyrus-sasl-devel cyrus-sasl-gssapi cyrus-sasl-plain flex gcc gcc-c gdb git java-1.8.0-openjdk-devel krb5-server krb5-workstation libtool make openssl-devel patch pkgconfig…

关于Outlook删除原邮箱邮件的解决办法

最近需要用邮件多一些&#xff0c;就配置了一下Outlook客户端&#xff0c;配置的时候一般直接点下一步&#xff0c;自动配置就可以了&#xff0c;我也试过手动配置&#xff0c;解决老是出问题。别说&#xff0c;Outlook用起来还是相当方便的&#xff0c;不用每次都打开浏览器输…

解决MAPGIS导出数据乱码

所需软件&#xff1a; MAPGIS6.7 MAPGIS10版本以上 MAPGIS开发入门向导手册.zip-行业报告文档类资源-CSDN下载MAPGIS开发入门向导手册.zip更多下载资源、学习资料请访问CSDN下载频道.https://download.csdn.net/download/qq_39397927/85321238ArcGIS 问题描述 在mapgis中的…

r语言中的或怎么表示什么不同_s语言和r语言有什么区别

展开全部一、用法不同1、S语言&#xff1a;S语言用来进行数据探索、统计分析、作图的解释型语62616964757a686964616fe58685e5aeb931333431366261言。2、R语言&#xff1a;R是自由软件&#xff0c;是一种可编程的语言。二、开发人员不同1、S语言&#xff1a;语言是由AT&T贝…

AsyncTask的用法

在开发Android应用时必须遵守单线程模型的原则&#xff1a; Android UI操作并不是线程安全的并且这些操作必须在UI线程中执行。在单线程模型中始终要记住两条法则&#xff1a; 1. 不要阻塞UI线程 2. 确保只在UI线程中访问Android UI工具包 当一个程序第一次启动时&#x…

突破select的FD_SETSIZE限制

前言&#xff1a; 在很多比较各种网络模型的文章中&#xff0c;但凡提到select模型时&#xff0c;都会说select受限于轮询的套接字数量&#xff0c;这个 数量也就是系统头文件中定义的FD_SETSIZE值(例如64)。但事实上这个算不上真的限制。 C语言的偏方&#xff1a; 在C语…

袋装树和随机森林的区别

装袋法建树的时候是将所有预测变量都考虑进去&#xff0c; 而随机森林则是考虑每一个分裂点时&#xff0c;都是从所有的预测变量p中随机选取m个预测变量&#xff0c;分裂点所用的预测变量只能从这m个变量中选择。

如何导入maven源文件_如何正确导入maven项目到eclipse?

Eclipse不允许一个项目被导入不止一次,在您的情况下,来自中继线和分支.This article显示了如何通过自定义maven配置文件绕过此限制.基本上,步骤是&#xff1a;>将以下配置文件添加到您的父pom.xml中append-to-project-nameappend.to.project.namemaven-eclipse-plugin[artif…

画廊效果

http://www.no3dfx.com/polaroid/ 转载于:https://www.cnblogs.com/bearhb/archive/2011/10/12/2208162.html

python镜像

Python国内镜像地址&#xff1a; 1.阿里云&#xff1a;https://mirrors.aliyun.com/pypi/simple/ 2.豆瓣&#xff1a;https://pypi.douban.com/simple/ 3.清华大学&#xff1a;https://pypi.tuna.tsinghua.edu.cn/simple/ 4.中国科学技术大学 http://pypi.mirrors.ustc.edu.cn/…

socket 编程入门教程(一)TCP server 端:3、sockaddr与sockaddr_in

收件人地址一家化妆品公司将一批新产品的样品&#xff0c;准备发给某学校某个班的女生们免费试用。通常情况下&#xff0c;这件邮包的地址上可以这么写&#xff1a;收件人&#xff1a;全体女生。 地址&#xff1a;A省B市C学校&#xff0c;X级Y班。但是&#xff0c;如果在描述地…

python语言为什么叫python_Python为什么叫Python,Java又如何而来?

你可能听过这样一种说法&#xff1a;在计算机科学领域&#xff0c;只有两件困难的事情&#xff0c;其中一件是给事物命名。有些编程语言的名字很有意义&#xff0c;比如谷歌(Google)将它的编程语言命名为Go(lang)&#xff0c;而其他的名字——比如Python和Java——为什么要这么…

arcgis中的SetNull(,)函数使用

SetNull(设置条件&#xff0c;将条件之内的值变为nodata,条件之外的值处理) 例如&#xff1a; 1.setnull("DEM"500,"DEM"),将DEM中值为500的数据赋为空&#xff0c;其他保留原值 2.setnull("DEM">500,"DEM"),将DEM中值大于500的…

pyqt5设置dialog的标题_PyQt5快速上手基础篇7-弹出dialog

前言本节我们学习QDialog的使用&#xff0c;在主页面点击按钮弹出一个新的Dialog。一、基础知识1. dialog简介窗口是GUI设计中不可获取的一部分&#xff0c;方便用户和程序直接交互&#xff0c;简化使用&#xff1b;Qdialog主要包含QInputDialog、QColorDialog、QFontDialog、Q…

67、ulimit的使用

1、ulimit set or get the shells resource usage limits ulimit [OPTIONS] [LIMIT] 2、option ① -a 显示当前所有的资源限制。 ② -c size:设置core文件的最大值。单位:blocks ③ -n size 指定同一时间最多可开启的文件数 ④ -l size:设置在内存中锁定进程的最大值。单位:KB…

如何处理MODIS蒸散数据(ET)中的填充值(仅作参考)

该处理过程是个人想法&#xff0c;仅做参考&#xff0c;如果想要等到比精确的蒸散数据请参考《京津唐地区城市扩张对地表蒸散发的影响》中蒸散的计算过程。 MOD16A3 第 6 版蒸发蒸腾/潜热通量产品是按 500 米 (m) 像素分辨率生成的年度复合数据集。 根据《京津唐地区城市扩张对…