百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

VBA连接Mysql数据库 vba怎么连接数据库sql

qiyuwang 2024-10-09 17:41 16 浏览 0 评论

本篇文章分享VBA连接Mysql数据库的具体步骤。包含以下几个部分:


■MySQL的环境配置

■VBA连接MySQL数据库的代码框架



一、MySQL的环境配置


我的具体环境:

√Win7 32位系统

√Excel 2016 32bit

√Mysql服务+数据库管理工具(我用的Navicat)

√Mysql ODBC连接器

√VC++ 2015 Redistributable(一个必须环境)


切记!上述组件务必安装相同位数的版本,否则容易出现各种问题!


(所有文中涉及到的附件,32和64位版本均提供安装包,后台回复mysql获取)









▍确保以上程序均安装完成以后,开始下面的配置环境。


①打开“控制面板”-“管理工具”-“ODBC 数据源”(找不到管理工具的,搜索一下)

②添加Mysql数据源驱动



③点击完成后弹出配置界面,关于界面的说明如下:

我这里使用的是Navicat数据库管理软件,下面的界面也是Navicat里面连接设置页面。如果成功的话,点Test之后会出现连接成功的提醒。


到这一步,我们已经成功了一半了,下面只需要知道VBA连接Mysql的框架代码即可。



二、VBA中使用代码连接MySQL

现在给出连接Mysql数据库的框架代码


▍框架代码:

Sub 连接本地Mysql()
 '///1. 引用ADO类库:前期或者后期绑定
 Dim conn As ADODB.Connection
 Set conn = New ADODB.Connection '以上两句可简写Dim con As New ADODB.Connection
 Dim rs As ADODB.Recordset
 Set rs = New ADODB.Recordset '以上两句可简写Dim rs As New ADODB.Connection
 '///2. ADO建立对数据源的链接
 conn.ConnectionString = "Driver={MySQL ODBC 8.0 Unicode Driver};Server=127.0.0.1;Port=3306;DB=myemployees;UID=root;PWD=123;OPTION=3;"
 conn.Open
 '///3. ADO执行SQL语言。
 rs.Open "select * from jobs", conn '使用结果集对象执行sql语句
 Range("A2").CopyFromRecordset rs '将数据输出到工作表,不包含字段名
 '可简写con.Open "Driver={MySQL ODBC 8.0 Unicode Driver};Server=192.168.1.139;DB=test;UID=root;PWD=abc;OPTION=3;"
 MsgBox ("连接成功!" & vbCrLf & "数据库状态:" & conn.State & vbCrLf & "数据库版本:" & conn.Version)
 conn.Close
 Set conn = Nothing
End Sub




代码主要分为三大部分:

■引用ADO类库:前期或者后期绑定

■ADO建立对数据源的链接

■ADO执行SQL语言


???关于引用ADO类库:


连接数据库需要通过ado这个中间人。首先我们要引用ado组件的类型库,这里我采用前期绑定的方式。


在VBE菜单栏选择“工具”-“引用”,在弹出的引用窗口中,找到"Microsoft ActiveX Data Objects 6.1 Library"和"Microsoft ActiveX Data Objects Recordset 6.0Library",把前面的框勾选上,点击确定即可。(如果不是这两个版本,则选择一个版本号最高的勾选即可)


???ADO的连接字符串



 conn.ConnectionString = "Driver={MySQL ODBC 8.0 Unicode Driver};Server=127.0.0.1;Port=3306;DB=myemployees;UID=root;PWD=123;OPTION=3;"


Driver变量:值是必须要和数据源中添加的新数据源一致的,否则会提示找不到数据源。


Server变量:本地Mysql服务器,输入127.0.0.1,;远程服务器输入相应服务器IP地址。

Port变量:端口号

DB变量:数据库名字

UID变量:用户名

PWD变量:密码


???执行sql语句:


通常我们使用ADO的Execute语句Recordset对象执行SQL语句。


 将SQL查询结果和字段名写入表格指定区域
 Sql = "SELECT 姓名,成绩 FROM [Sheet1$] WHERE 成绩>=80"
 'Sql语句,查询Sheet1表成绩大于80……姓名和成绩的记录
 Set rst = cnn.Execute(Sql)
 'cnn.Execute()执行SQL语句,始终得到一个新的记录集rst
 For i = 0 To rst.Fields.Count - 1
 '利用fields属性获取所有字段名,fields包含了当前记录有关的所有字段,fields.count得到字段的数量
 '由于Fields.Count下标为0,又从0开始遍历,因此总数-1
 Cells(1, i + 4) = rst.Fields(i).Name
 Next
 Range("d2").CopyFromRecordset rst
 '使用单元格对象的CopyFromRecordset方法将rst内容复制到D2单元格为左上角的单元格区域



原创不易,如果你觉得不错,希望你能帮忙转发

相关推荐

第二十六章 Bat文件(bat文件百科)

第二十六章Bat文件bat文件是dos下的批处理文件。批处理文件是无格式的文本文件,它包含一条或多条命令。它的文件扩展名为.bat或.cmd。在命令提示下输入批处理文件的名称,或者双击该批处理...

自媒体良器:音频文件批处理,FFmpeg一行搞定!果断收藏

引言FFMpeg是众多多媒体应用程序的核心,但该程序本身不具备一次转换多个文件的能力。但也拦不住,FFMpeg本身是命令行程序,可编写脚本,借助Bash轻松快速地构建自动化程序。...

批处理:创建和删除文件夹命令(批处理命令 删除文件夹)

上一期,我们学习了文件夹的查看命令:tree和dir,以及文件夹切换命令:cd,今天,我继续给大家讲解下批处理的目录(文件夹)操作命令:创建和删除。一.md:创建目录(文件夹)可以在当前文件夹下创建...

利用VBA创建新的工作簿(vba 创建工作簿)

【分享成果,随喜正能量】我告诫自己:你的话说得太多,你听别人倾诉得太多,你咖啡喝得太多,你在陌生的房间里坐的时间太长,你的睡眠质量太差,你醒着的时间太长,你平庸的事想得太多,你希望过多,你安慰自己太频...

实用小工具,注册表文件快速转换.bat文件

关于注册表注册表是Windows操作系统中的一个核心数据库,它用于存储系统和应用程序的设置信息。这个数据库文件控制着Windows操作系统的外观和如何响应外来事件的工作方式。注册表包含了各种参数,直接...

如何给自己的电脑做一个截图工具?现场教会你具体流程和步骤

做自媒体,经常要用到一些图片,有时候图片上有水印去不掉,这时候要是有一个能随意截图的工具该有多少呀!今天教授让大家自己设计一个截图工具。下面就是流程和步骤:1、在电脑页面的任意位置,点击鼠标右键,新建...

Windows使用批处理文件更改目录下的文件名(含序号)

从网上下载的图片,默认的名字是由许多字母和数字组成的比较长的一个字符串,不便于人记忆,使用起来比较麻烦。如下图所示:本文的目的是写一个批处理文件,将该目录中的所有扩展名为jpeg的文件改名为日期加序号...

学习VB编程第35天,如何调用bat批处理

今天学习了刘金玉老师零基础VB教程的第43期,学习的主要内容是如何调用bat批处理登录。一、什么是批处理1.什么是命令提示符(cmd)?在Windows开始菜单运行(windows+r键也可调出)中输...

利用bat让文件在指定时间自动进行备份

在很多时候,我们需要备份电脑中的一些文件,特别是企业服务器的备份,可能是有一些文件每天都会有更新,或者定期更新,而文件又是相对比较重要的,需要我们定时去备份。可有时候文件比较大,备份时间比较长,或者在...

BAT 批处理脚本教程(批处理脚本编写教程)

BAT批处理脚本教程第一章批处理基础第一节常用批处理内部命令简介批处理定义:顾名思义,批处理文件是将一系列命令按一定的顺序集合为一个可执行的文本文件,其扩展名为BAT或者CMD。这些命令统称批处...

Windows系统bat批处理常用命令(一)

一、批处理中常用的命令:@命令:加在每个命令行的最前面,表示运行时不显示这一行的命令行。eg:@echooff//不显示后续命令行及当前命令行...

编写bat文件在windows上自动执行cmd命令

windows电脑上直接新建txt记事本文件,编写好要执行的命令后,将后缀修改成.bat,然后直接点击文件就可以执行里面的命令了#打开命令窗口startcmd#/k执行完命令不关...

不会C语言写bat脚本代码批量修改文件名,DeepSeek帮你解决!

哈喽大家好,我是小飞。今天给大家讲一下DeepSeek做了一个批量修改文件夹的bat脚本。·首先先让它这样修改一下,因为之前已经做过一个,然后它没有改,现在让它修改一下,把它修改一个很智能的BAT脚本...

BAT批处理命令之ren/rename(与Excel合作批量修改文件名)

写在前面一鸽就是半年...

使用批处理文件——autoexec.bat(批处理more)

1、dblspace.sys磁盘压缩。  drvspace.sys、dblspace和drvspace是Microsoft公司推出的磁盘压缩工具,可以将磁盘的空间增加许多,但由于它依靠对文件进行压...

取消回复欢迎 发表评论: