zoukankan      html  css  js  c++  java
  • MFC连接MySQL

    其实,以前弄过sql,mysql应该是顺理成章很简单的事情,但很无奈,傻傻地弄了很久,还请教了别人,别人告诉我的跟我在网上查到的都是一样的,但还是不行,归根接地就是“mysql-connector-odbc-5.2.4-win32”这个odbc这里版本号出了问题。

    自己下载的是MySQL-installer-community-5.6.10.1(含odbc5.2.4),装完后发现自带了odbc5.2.4,接下来的操作很自然用了“Driver=MySQL ODBC 5.2 Driver”这里就出问题了,版本号一定要弄清楚,否者肯定要出错,当然很多人自己下的odbc所以根本不会出这个问题,这里只是一个无知者的提醒。出现的ODBC5.1是自己装的,你直接用“Driver=MySQL ODBC 5.1 Driver”自然也是没问题。

    一、非ODBC

    1.下载mysql数据库.(mysql-5.1.28-rc-win32)

    2.下载与mysql数据库版本相同的odbc(mysql-connector-odbc-noinstall-5.1.8-win32),两者版本必须相同,否则会报错。

    3.可以下载MySql-Front工具,可视化对MySql操作。

    3.打开MFC程序,在stdafx.h中加入一句:

    #import "C:Program FilesCommon FilesSystemadomsado15.dll" no_namespace rename("EOF","rsEOF")

    4.在要打开的cpp程序中加入以下语句,变量也可定义到头文件,adModeUnknown是数据库访问权限常量,我输入别的都不行,就输入这个可以,权限设置还要再学习。

     CoInitialize(NULL);

     _ConnectionPtr pConn;
    _RecordsetPtr pRs("ADODB.Recordset");

     pConn.CreateInstance(__uuidof(Connection));
      HRESULT hr=pConn->Open("Driver=MySQL ODBC 5.2wDriver;Server=127.0.0.1;Database=test","root","123456",adModeUnknown);


     pRs->Open("Select * From avInfo",_variant_t(pConn,true),adOpenStatic,adLockOptimistic,adCmdText);

     CString strID= (LPCTSTR)_bstr_t(pRs->GetCollect("FlightNO"));

    二、ODBC

    跟非odbc的唯一区别在

    m_pConnectionPtr->Open("DSN=FEIFEI;Server=localhost;Database=feifei","root","19880512",adModeUnknown);//成功,当然要配置odbc,data source name =FEIFEI

    配置如下:

    三、C API方式(自己就没用过了)

    一、环境

    编译环境: VS2008

    MySql版本:mysql-5.5.18-win32.msi  

    下载地址:点击打开链接 

    MYSQL官网,选择的是MySQL Community Server 

    二、安装连接

    安装步骤:资料来源百度文库或者CSDN下载,貌似百度文库方便点

    VS编译,提示找不到#include<mysql.h>

    通过VC开发MySQL数据库应用软件有多种方式:   

      一、通过MyODBC界面  
      二、通过Connector/C++l界面   
      三、通过MySQL CAPI界面  
      四、第三方封装的MySQL类   
        
      在经过反复比较,我还是选择了MySQLC API方式来进行MySQL的开发。   
      在VC中使用MySQL的步骤如下:   
        
      1、下载MySQL的服务器/客户端安装包   
      官方下载地址如下:  
      http://www.mysql.com/downloads/mysql-4.0.html   
      由于我的开发环境是Windows,所以我下载的是MySQL for Windows V4.0.12  
        
      2、安装MySQL服务器/客户端包   
      一般情况,选择下一步就行了。  
      默认情况,MySQL会安装到C:mysql下。   
        
      3、在VC中设置其开发环境   
      [选项/项目/VC目录]   
      a.设置包含路径为c:mysqlinclude  
      b.设置引用路径为c:mysqlinclude  
      c.设置库路径为c:mysqllibdebug  

     a、b、c均不可少
      [项目属性]  
      d.在设置链接器-输入-附加依赖项为libmySQL.lib   

      在stdafx.h中加入以下行:   
      #include <winsock.h>   
      #include "mysql.h"   

     或者不需要设置链接器,可在stdxfx.h需多添加一行,等同效果

    #pragmacomment(lib,"libmysql.lib")    

      4、至此就可以使用C API函数进行开发了。

     FAQ:   
      1.若出现无法使用mysql.h定义的类型的错误时,可重新生成工程即可.      
      2.若出现链接错误,可将libmySQL.dll文件拷贝到工程当前目录下.   

    三、Mysql API函数

      MySQL提供了很多函数来对数据库进行操作,大致可以分为以下几类:      
      第一部分 控制类函数   
        
      mysql_init()初始化MySQL对象  
      mysql_options()设置连接选项   
      mysql_real_connect()连接到MySQL数据库      
      mysql_real_escape_string()将查询串合法化   
      mysql_query()发出一个以空字符结束的查询串   
      mysql_real_query()发出一个查询串       
      mysql_store_result()一次性传送结果   
      mysql_use_result()逐行传送结果       
      mysql_free_result()释放结果集       
      mysql_change_user()改变用户   
      mysql_select_db()改变默认数据库       
      mysql_debug()送出调试信息   
      mysql_dump_debug_info()转储调试信息       
      mysql_ping()测试数据库是否处于活动状态   
      mysql_shutdown()请求数据库SHUTDOWN       
      mysql_close()关闭数据库连接   


      第二部分 信息获取类函数   
      mysql_character_set_name()获取默认字符集   
      mysql_get_client_info()获取客户端信息   
      mysql_host_info()获取主机信息   
      mysql_get_proto_info()获取协议信息   
      mysql_get_server_info()获取服务器信息   
      mysql_info()获取部分查询语句的附加信息   
      mysql_stat()获取数据库状态       
      mysql_list_dbs()获取数据库列表   
      mysql_list_tables()获取数据表列表   
      mysql_list_fields()获取字段列表   
        
      第三部分 行列类操作函数   
      mysql_field_count()获取字段数   
      mysql_affected_rows()获取受影响的行数   
      mysql_insert_id()获取AUTO_INCREMENT列的ID值      
      mysql_num_fields()获取结果集中的字段数   
      mysql_field_tell()获取当前字段位置   
      mysql_field_seek()定位字段   
      mysql_fetch_field()获取当前字段   
      mysql_fetch_field_direct()获取指定字段   
      mysql_frtch_fields()获取所有字段的数组     

      mysql_num_rows()获取行数   
      mysql_fetch_lengths()获取行长度   
      mysql_row_tell()获取当前行位置   
      mysql_row_seek()行定位   
      mysql_data_seek()行定位   
      mysql_fetch_row()获取当前行   
        
        
      第四部分 线程类操作函数   
      mysql_list_processes()返回所有线程列表   
      mysql_thread_id()获取当前线程ID   
      mysql_thread_safe()是否支持线程方式   
      mysql_kill()杀列一个线程   
        
        
      第五部分 出错处理类函数   
      mysql_errno()获取错误号   
      mysql_error()获取错误信息   
        
      第六部分 已过时的函数   
      mysql_connect()   
      mysql_create_db()   
      mysql_drop_db()   
      mysql_eof()   
      mysql_reload()   
      mysql_escape_string()   

     收集相关文章地址:

    1、《vs2008下c++链接mysql》   http://blog.csdn.net/luxiaoshuai/article/details/5644745

    2、《vc但文件连接mysql实例,丢掉libmysql.dll》 http://blog.csdn.net/zwfgdlc/article/details/5556654

    3、   《vs2008连接MySQL,采用C API方式http://blog.csdn.net/sciland/article/details/4274364

    以上转自:http://blog.csdn.NET/sciland/article/details/4274364

    另外,MySQL的语法大全也非常值得一看:http://wenku.baidu.com/view/29648f2458fb770bf78a552f.html

  • 相关阅读:
    jQuery取得select选择的文本与值
    jquery 广告效果
    【JNI知识一】JNI接口函数与指针
    jQuery 中bind(),live(),delegate(),on() 区别(转)
    用angular怎么缓存父页面数据
    js条件判断时隐式类型转换
    常用原生JS方法
    gulp批量打包文件并提取公共文件
    angular下H5上传图片(可预览,可多张上传)
    angular4运行 ng build prod出错
  • 原文地址:https://www.cnblogs.com/smh2015/p/6427512.html
Copyright © 2011-2022 走看看