分享

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

 Excel实用知识 2021-11-21

   编写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./downloads/connector/odbc

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

             

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

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

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

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

     3.连接示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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位的,始终无法正常打开连接。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多