ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: zhaogang1960

[讨论] SQL顺序连接多个工作簿速度的疑问,解释合理加技术分2分

  [复制链接]

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:01 | 显示全部楼层
lanyuu 发表于 2014-3-12 13:48
通过测试,我的推断是
创建数据连接对象时,先判断是否存在该对象,如果不存在,直接创建,如果存在, ...

部分同意您的观点,至少在单一的Object对象时,似乎有您说的这个过程,但2个或2个以上Object对象时,似乎又只有创建过程,没有注销过程。

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:03 | 显示全部楼层
没名字了 发表于 2014-3-12 13:33
说来说去,我感觉我们前面说的都错了
看下面的两个实例
Sub 实例1

你说的这个确实是个问题,看样子是否关闭连接不是简单的判断。

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:09 | 显示全部楼层
lanyuu 发表于 2014-3-12 14:03
你说的这个确实是个问题,看样子是否关闭连接不是简单的判断。

是的,至少在这个现象说明,速度的提升,可能不是因为单纯的使用了RS,可能是由于增加了Object对象,改变了系统某些运作的方式。至于这个方式是什么或者是不是我猜测的那样。期待答案。

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:17 | 显示全部楼层
没名字了 发表于 2014-3-12 14:09
是的,至少在这个现象说明,速度的提升,可能不是因为单纯的使用了RS,可能是由于增加了Object对象,改变 ...

我的判断是增加时间肯定是清空对象时关闭连接造成的,但是什么情况下不需要关闭连接的判断现在还不好说,因为有两个连接对象和存在连接记录集时都会直接清空对象。

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:26 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
  1. Sub 实例2()
  2. tt = Timer
  3.     Dim cnn As Object, cnn2 As Object, SQL$, Mypath$, MyName$, arr, brr(1 To 60000, -1 To 11), i&, j&, m&, n&
  4.     Application.ScreenUpdating = False
  5.     Mypath = ThisWorkbook.Path & ""
  6.     MyName = Dir(Mypath & "*.xls")
  7.     Set cnn2 = CreateObject("ADODB.Connection")
  8.     cnn2.Open "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=Excel 8.0;Data Source=" & Mypath & MyName
  9.     Do While MyName <> ""
  10.         If MyName <> ThisWorkbook.Name Then
  11.             Set cnn = CreateObject("ADODB.Connection")
  12.             cnn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=Excel 8.0;Data Source=" & Mypath & MyName
  13.         End If
  14.         MyName = Dir()
  15.     Loop
  16. MsgBox Timer - tt
  17. End Sub
复制代码
这样子似乎更快

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:33 | 显示全部楼层
赵兄附件中 Sub ADO加数组已知工作表名_2() 过程的循环前加上下面两句
Set cnn2 = CreateObject("ADODB.Connection")
    cnn2.Open "Provi

代码也被加速了

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:35 | 显示全部楼层
HHAAMM 发表于 2014-3-12 14:26
这样子似乎更快

我没有整理顺序,因为怎么让程序更快和这个课题无关,我仅仅是在找赵版老师提出的问题的原因,至于答案我想以我的水平可能不能去深入理解了。两个连接比一个连接速度快很多倍,唯一的区别就是Object对象的增加,似乎这个离原因比较接近。

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:43 | 显示全部楼层
没名字了 发表于 2014-3-12 14:35
我没有整理顺序,因为怎么让程序更快和这个课题无关,我仅仅是在找赵版老师提出的问题的原因,至于答案我 ...

不是因为快慢的问题能出现这个帖子吗??
97楼的帖子是在说,循环中不必一直这么要创建两个对象

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:45 | 显示全部楼层
我是说
Set cnn2 = CreateObject("ADODB.Connection")
    cnn2.Open "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=Excel 8.0;Data Source=" & Mypath
& MyName
    Do While MyName <> ""
        If MyName <> ThisWorkbook.Name Then
            Set cnn = CreateObject("ADODB.Connection")
            cnn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=Excel 8.0;Data Source=" & Mypath & MyName
        End If
        MyName = Dir()
    Loop
这样
似乎比下面这样
Do While MyName <> ""
        If MyName <> ThisWorkbook.Name Then
            Set cnn = CreateObject("ADODB.Connection")
            cnn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=Excel 8.0;Data Source=" & Mypath & MyName
            Set cnn2 = CreateObject("ADODB.Connection")
            cnn2.Open "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=Excel 8.0;Data Source=" &
Mypath & MyName
        End If
        MyName = Dir()
    Loop

还要稍稍快些

TA的精华主题

TA的得分主题

发表于 2014-3-12 14:49 | 显示全部楼层
如果真是这样,大家可以再接着分析原因吗

点评

也许这个open和getobject有异曲同工之妙  发表于 2014-3-12 15:26
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2025-1-12 21:50 , Processed in 0.024402 second(s), 7 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表