ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > Excel VBA > 如何在不用代码打开工作簿的前提下用ADO在工作簿之间传递数据?

如何在不用代码打开工作簿的前提下用ADO在工作簿之间传递数据?

作者:绿色风 分类: 时间:2022-08-17 浏览:113
楼主
水星钓鱼
Q:如下图所示为两个工作簿:

 
分别为“总表“、“分表”,现在需要将“总表”中性别为“男”的所有学生的记录提取到“分表”中,如何在不用代码打开工作簿的前提下用ADO实现呢?
A:可以用以下代码实现
  1. Private Sub CommandButton1_Click()
  2.     Dim oCon
  3.     Dim sConStr As String
  4.     Dim sSql As String
  5.     sConStr = "Provider='Microsoft.Jet.OLEDB.4.0';Data Source=" & ThisWorkbook.FullName & ";Extended Properties='Excel 8.0;HDR=YES'"
  6.     sSql = "INSERT INTO [Sheet1$] IN '' [Excel 8.0;Database=" & ThisWorkbook.Path & _
  7.     "\分表.xls] SELECT * FROM [Sheet1$] where 性别='男'"
  8.     Set oCon = CreateObject("ADODB.Connection")
  9.     With oCon
  10.         .Open sConStr
  11.         .Execute sSql
  12.     End With
  13.     Set oCon = Nothing
  14. End Sub
利用SQL的DDL语句中的INSERT INTO语句可以在能够被Microsoft.Jet.OLEDB.4.0连接访问的各种不同的数据源之间进行数据的传递,这里是两个Excel工作簿。
  1. INSERT INTO [Sheet1$] IN '' [Excel 8.0;Database=" & ThisWorkbook.Path & _
  2.     "\分表.xls] SELECT * FROM [Sheet1$] where 性别='男'
附件如下:

用ADO在不同的工作簿之间传递数据.rar


补充内容 (2014-1-11 20:53):
请使用帖子右下角的评分功能给这个帖子评分

补充内容 (2014-1-11 20:54):
请使用帖子右下角的评分功能给这个帖子评分
2楼
海洋之星
厉害,水星,
3楼
魔魔
和水版学习
4楼
老糊涂


5楼
白开水02
好牛的啊
6楼
yytax2010
正需要,谢谢!   
7楼
开心笑羊
很实用,谢谢。
8楼
yytax2010
用SQL语句简单搞定。

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap