Excel VBA连接MySql 数据库获取数据

Posted 天道酬勤2016

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Excel VBA连接MySql 数据库获取数据相关的知识,希望对你有一定的参考价值。

   编写Excel VBA工具,连接并操作mysql 数据库。

        系统环境:

               OS:Win7 64位 英文版

               Office 2010 32位 英文版

        1、VBA连接MySql前的准备

              Tools--->References..---->引用

              勾选Microsoft ActiveX Data Objects 2.8 Librarys 和Microsoft ActiveX Data Objects Recordset 2.8 Librarys

             

        2、安装Mysql ODBC连接服务

             下载连接:https://dev.mysql.com/downloads/connector/odbc

             注意:这里使用32位的版本

             

            下载上图中Windows(x86,32-bit),Zip Archive版本,在测试中,使用64位的版本无法连接到Mysql

            把下载上述文件拷贝放到资源管理器里,放到合适位置,解压,点击里面的install.bat批处理文件。

            从“控制面板”--->“管理工具”---->ODBC,打开以后,从这个里面无法看到Mysql的驱动,实际上使用的是下面32位的ODBC驱动

           C:\\Windows\\SysWOW64\\文件夹下的odbcca32.exe

     3.连接示例

       

Sub TestConnectTodb()
    Dim conn As ADODB.Connection
    Dim rs As ADODB.Recordset
    Set conn = New ADODB.Connection
    Set rs = New ADODB.Recordset
    conn.ConnectionString = "Driver={MySQL ODBC 5.3 Unicode Driver};Server=localhost;Port=3306;Database=db_hptms;Uid=root;Pwd=123456;OPTION=3;"
    conn.Open
    rs.Open "select fdEmpNo,fdEmpName from tbUser", conn
    With ThisWorkbook.Worksheets("MySqlData")
         .Visible = True
         .Range("a1:b1").Value = Array("EmpNo", "EmpName")
         .Range("A2").CopyFromRecordset rs
         .Activate
    End With
    rs.Close: Set rs = Nothing
    conn.Close: Set conn = Nothing
    MsgBox "处理完毕", vbOKOnly, "提示信息"
End Sub

 

      上述示例经过测试,可以正常连接到Mysql数据库,这里注意使用的ODBC连接的版本是32位,在测试中,使用64位的,始终无法正常打开连接。

     

以上是关于Excel VBA连接MySql 数据库获取数据的主要内容,如果未能解决你的问题,请参考以下文章

EXCEL的VBA通过SSH连接MYSQL

Excel VBA 连接SQL数据库后的操作。

EXCEL的VBA ,连接数据库,运行时错误 424 要求对象

求助,EXCEL通过VBA操作SQL数据库

从VBA Excel 2007打开与MySQL的连接

Excel VBA 连接各种数据库 VBA连接SQL Server数据库