热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

不安装ODBC怎样用VBA连接Mysql数据库

如果没有安装ODBC该怎样用VBA连接Mysql数据库呢?给大家介绍一种方法。不仅可以连接数据库,并且代码更简洁和Excel也具有更好的交互性。我们需要安装一个插件,SqlCelF

如果没有安装ODBC该怎样用VBA连接Mysql数据库呢?

给大家介绍一种方法。不仅可以连接数据库,并且代码更简洁和Excel也具有更好的交互性。

我们需要安装一个插件,SqlCelFuncs或者SqlCel用SqlCel函数来实现此功能。如下:

'引用SqlCel插件必写(随便写在哪个模块中都可以)
Public Function s() As Object
Set s = Application.COMAddIns("SqlCelAddIn").Object
End Function
'先定义两个连接,提前运行一下就会生成两个连接字符串,一直存在随时可用
Sub DefMysqlConnection()
s.DefMysqlConn "firstdb", "127.0.0.1", "test", "root", "123456", "3306", "utf8"
s.DefMysqlConn "seconddb", "127.0.0.1", "test2", "root", "123456", "3306", "utf8"
End Sub
'主程序入口
Sub QueryMysql()
s.UseConn "Mysql", "firstdb" '使用名为firstdb的Mysql连接
Call QueryToRs '从firstdb中查询数据
s.UseConn "Mysql", "seconddb" '使用名为seconddb的Mysql连接
Call QueryToArr '从seconddb中查询数据
Call QueryToQax '从seconddb中查询数据
End Sub
'将数据查到Recordset数据集中
Sub QueryToRs()
Dim rs As Object, i As Integer
Set rs = s.QueryToRs("SELECT * FROM cars")
With Sheets("TB1")
For i = 0 To rs.Fields.Count - 1
.Cells(1, i + 1).Value = rs.Fields(i).Name
Next i
.Range("A2").CopyFromRecordset rs
End With
End Sub
'将数据查到二维数组中
Sub QueryToArr()
Dim arr As Variant
arr = s.QueryToArr("SELECT* FROM colleges", True)
s.ArrayToExcel arr, Sheets("TB3").Range("A1")
End Sub
'将数据查询到QAX(DataTable)中
Sub QueryToQax()
Dim qax As Variant
Set qax = s.QueryToQax("SELECT * FROM colleges")
s.QAXToRng qax, Sheets("TB2").Range("A1"), "TableStyleDark10", True
End Sub

最后一个查询的效果如下:
《不安装ODBC怎样用VBA连接Mysql数据库》
sqlcel函数官网介绍:
https://sqlcel.com/sqlcelfuncs/


推荐阅读
  • 本文介绍了PhysioNet网站提供的生理信号处理工具箱WFDB Toolbox for Matlab的安装和使用方法。通过下载并添加到Matlab路径中或直接在Matlab中输入相关内容,即可完成安装。该工具箱提供了一系列函数,可以方便地处理生理信号数据。详细的安装和使用方法可以参考本文内容。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • Android日历提醒软件开源项目分享及使用教程
    本文介绍了一款名为Android日历提醒软件的开源项目,作者分享了该项目的代码和使用教程,并提供了GitHub项目地址。文章详细介绍了该软件的主界面风格、日程信息的分类查看功能,以及添加日程提醒和查看详情的界面。同时,作者还提醒了读者在使用过程中可能遇到的Android6.0权限问题,并提供了解决方法。 ... [详细]
  • MFC程序连接MySQL成功实现查询功能,但无法实现修改操作——详解查询语句在MySQL中的使用过程
    selectxxx,xxx,xxxfromxxxwherexxxxxx,xxxxxx程序的日常开发中,我们经常会写到各种各样的简单的,复杂的查询sql语 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • 解决VS写C#项目导入MySQL数据源报错“You have a usable connection already”问题的正确方法
    本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • Jboss的EJB部署描述符standardjaws.xml配置步骤详解
    本文详细介绍了Jboss的EJB部署描述符standardjaws.xml的配置步骤,包括映射CMP实体EJB、数据源连接池的获取以及数据库配置等内容。 ... [详细]
  • .NET中各种数据库连接大全(转)[more].NET中各种数据库连接大全sql.gif)SQLSERVEROdbCStandardSecurity:driver{SQLSe ... [详细]
  • jsp数据库多行返回(excel返回多行数据)
    本文目录一览:1、数据库数据怎么返回到jsp页面上 ... [详细]
author-avatar
mobiledu2502868933
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有