ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[已解决] 发这板块才对:纠结于一个问题,SQL 转数组就这么复杂吗,非要往返两次

[复制链接]

TA的精华主题

TA的得分主题

发表于 2013-9-13 14:39 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 andanok 于 2013-9-13 21:06 编辑

Sub 更新链接()
    Dim iRow
    Dim con As New ADODB.Connection
    Dim rs As New ADODB.Recordset
    Dim WshShell, BtnCode
    Dim SQL As String
            con.Open "Provider=SQLOLEDB;Data Source=(local); User ID=sa;Password =123;Database=test;" '打开本地服务器
     iRow = [E:E].Find("*", SearchOrder:=xlByRows, LookIn:=xlValues, SearchDirection:=xlPrevious).EntireRow.Row
      
    Dim Dic As Object, i%, j%
    Set Dic = CreateObject("Scripting.Dictionary")
   
    SQL = "Select SKU,ProductId from Products" '查询
    Arr = Application.Transpose(con.Execute(SQL).GetRows)
   
    Range("C2:D" & iRow) = Arr
    Arr = Range("C2:D" & iRow)
    For i = 1 To UBound(Arr)
        Dic(Arr(i, 1)) = Arr(i, 2)
    Next
   
    brr = Range("E2:E" & iRow)
    For j = 1 To UBound(brr)
        brr(j, 1) = Dic(brr(j, 1))
    Next
   
    Range("Z2:Z" & iRow) = brr
   
   
    con.Close
    Set con = Nothing

End Sub
其实只要VLOOKUP效果,数据量大的远程更新到EXCEL
Z2=VLOOKUP(E2,【SQL中表Products的SKU,ProductId】,0)
Z3=VLOOKUP(E3,……
……
现在只现实SQL到C、D列,再进行字典找对应的,能否不用过度的C、D列,更简单点呢,毕竟数据量大,多一步就会影响速度了,谢谢各位了









TA的精华主题

TA的得分主题

发表于 2013-9-13 20:57 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
你是常用EXCEL的人吧,看你很喜欢用数组啊
要让SQL返回查询的结果呢,看你的情况可大致使用两类方法
1.一条条传递条件,然后一条条返回结果:这类方法呢也就是组成一条有where的筛选SQL语句,让SQL返回相关结果或记录
2.批量上传条件记录。返回结果记录集:这类方法呢,就是批量上传条件,当然可在SQL服务器上创建临时表,放上相关条件,上传条件完成后,再逐条形成查询结果,并写在这个临时表里,查询完后。批量返回客端

不过象你要象VLOOKUP的话,用第一种,如果是一个列表下来都VLOOKUP的话,两种都可采用

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-9-13 21:06 | 显示全部楼层
Renco 发表于 2013-9-13 20:57
你是常用EXCEL的人吧,看你很喜欢用数组啊
要让SQL返回查询的结果呢,看你的情况可大致使用两类方法
1.一 ...

谢谢,我用SQL+字典+数组,这样连接服务器最少,更快更不容易出错,数据返回再编辑就稳当多了

TA的精华主题

TA的得分主题

发表于 2013-9-13 22:49 | 显示全部楼层
更快??把所有数据返回来,会快啊?!
你的快是怎么定义的啊?!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-17 16:15 , Processed in 0.030294 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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