【EXCEL_VBA_基础知识】15 使用ADO操作外部数据

课程来源:王佩丰老师的《王佩丰学VBA视频教程》,如有侵权,请联系删除!

目录

[1. 使用ADO链接外部数据源](#1. 使用ADO链接外部数据源)

[2. 常用SQL语句(Execute(SQL语句))](#2. 常用SQL语句(Execute(SQL语句)))

[2.1 查询数据、查询某几个字段、带条件查询、合并两表数据、插入新纪录](#2.1 查询数据、查询某几个字段、带条件查询、合并两表数据、插入新纪录)

[2.2 修改、删除一条数据、Vlookup、查询结果赋值到数组](#2.2 修改、删除一条数据、Vlookup、查询结果赋值到数组)

[2.3 注意事项(select语句 执行顺序)](#2.3 注意事项(select语句 执行顺序))

[3. 抓取数据实例](#3. 抓取数据实例)


1. 使用ADO链接外部数据源

vbnet 复制代码
' Excel文件
' 中间的两双引号其中一个为转义字符

Dim conn As New ADODB.Connection
conn.Open "Provider = Microsoft.ACE.OLEDB.12.0;Data Source=D:\data\Edata.xlsx; _
extended properties=""excel 12.0;HDR=YES"""
conn.Close

' ACCESS文件
conn.Open "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\data\Adata.accdb"

' Mysql数据库
conn.Open  "Provider=SQLOLEDB;DataSource=" & Path & "; _
Initial Catolog=" & strDataName


' MSSQL数据库
conn.Open  "Provider=MSDASQL;Driver={SQL Server}; _
Server=" & Path & ";Database=" & strDataName

' Oracle数据库
conn.Open  "Provider=madaora;Data Source=MyOracleDB; _
 User Id=UserID; Password=Password"

2. 常用SQL语句(Execute(SQL语句))

2.1 查询数据、查询某几个字段、带条件查询、合并两表数据、插入新纪录

2.2 修改、删除一条数据、Vlookup、查询结果赋值到数组

2.3 注意事项

2.3.1 SQL LEFT JOIN 与 Right JOIN(参考:SQL LEFT JOIN 关键字

LEFT JOIN :左表 (table_name1) 返回所有的行,即使在右表 (table_name2) 中没有匹配的行。

2.3.2 SQL Select语句执行顺序(自右向左)

1. 先执行红框语句,生成数据源表

2. 其次执行select语句,选择包含所选字段的数据(选择列)

3. 抓取数据实例

vbnet 复制代码
'使用前请确认是否勾选了Microsoft ActiveX Data Object  x.x  Library!!!
' VBA → 工具 → 引用
Sub Scrape_data()

Dim conn As New ADODB.Connection
Dim sql As String

' 清空当前sheet数据
ActiveSheet.Range("a2:z1000").ClearContents 

'注意这个链接文件的路径!!!需要把edata文件放入d:\data文件夹!!
conn.Open ("Provider = Microsoft.ACE.OLEDB.12.0;_
Data Source=D:\data\Edata.xlsx;extended properties=""excel 12.0;HDR=YES""")

sql = "select a.姓名,年龄,性别,月薪 from (select * from [data$] union all select * from [data2$])a left join [data3$] on a.姓名=[data3$].姓名"

'仅返回数据(不会返回表头,因已select)
ActiveSheet.Range("a2").CopyFromRecordset conn.Execute(sql) 

conn.Close
End Sub
相关推荐
Non-existent98714 小时前
WPS批量清理单元格空白字符的4种方法-异常数字格式处理-实战
excel·wps
Channing Lewis18 小时前
PHP 解析 Excel 的那些坑:一次“行号错位”引发的数据丢失
开发语言·php·excel
jarreyer20 小时前
【数据分析绘图】excel绘图和bi工具区别
数据挖掘·数据分析·excel
chatexcel21 小时前
ChatExcel Max使用教程:图片、PDF、网页与复杂Excel的一站式数据分析
数据分析·pdf·excel
cngkqy21 小时前
excel从某一列中用match筛选匹配的数据
excel
qq_546937271 天前
Excel批量转PDF_Word_图片,支持自动合并报表,效率翻倍。
pdf·word·excel
ai_coder_ai1 天前
在自动化脚本中操作excel文件
运维·自动化·excel
三千花灯1 天前
【Playwright】 自动化测试之参数化登录(Excel/CSV 数据源)
人工智能·机器学习·excel
罗政1 天前
AI工作流实现Excel全自动化(支持SQL)-案例:医院门诊排班表
人工智能·自动化·excel
小妖6661 天前
excel 怎么在单元格内容自动加上一段文字不能用公式
excel·vba