ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[讨论] Excel用ado从access取数速度优化思路

[复制链接]

TA的精华主题

TA的得分主题

发表于 2022-5-22 04:57 来自手机 | 显示全部楼层 |阅读模式
假设有一个access数据库,里面有N张表,各表之间有各种相关关系。
然后建立一个查询,查询几乎包含了所有表的各种字段和计算字段,即查询结果是一个字段很多的宽表。
然后在Excel里用ado连接从这个查询里面取数生成报表。

因为数据量有点大,几十万行以上,生成这个查询耗时要好几秒。而在Excel取数生成报表用的比较频繁,因此想到一个思路,先把这个查询结果转化为表,然后Excel直接从这个表里面取数,这样会不会提高速度呢?

简而言之,Excel用ado连接access取数,从查询中取数和从表取数的速度会有区别吗?

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-5-22 19:16 | 显示全部楼层
看来这个问题也是要我自己来实践测试一下了.

TA的精华主题

TA的得分主题

发表于 2022-5-26 18:22 来自手机 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
望告知测试结果

TA的精华主题

TA的得分主题

发表于 2022-6-14 19:49 | 显示全部楼层
当然时表更快,生成表会占用磁盘,运行时会占用内存,查询只在运行时存在,所以会慢,这种情况一般是优化你的SQL

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-6-15 01:55 来自手机 | 显示全部楼层
onlyflyttn 发表于 2022-6-14 19:49
当然时表更快,生成表会占用磁盘,运行时会占用内存,查询只在运行时存在,所以会慢,这种情况一般是优化你 ...

最近忙也还没测试,感觉应该是你说的这个道理。不过想着是经常每次写SQL语句都要去拼接计算字段之类的,就想着一次先拼好一个大表。看来要么节省拼SQL的时间要么节省运行时间难以两全其美了

TA的精华主题

TA的得分主题

发表于 2022-6-15 17:00 | 显示全部楼层
这不就是临时表的作用?
不过,临时表这么大,意义也不是太大
可以三方面入手:
1、优化查询,2、建立合适的索引,3、只取必要的数据

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-6-17 00:24 | 显示全部楼层
504373 发表于 2022-6-15 17:00
这不就是临时表的作用?
不过,临时表这么大,意义也不是太大
可以三方面入手:

听说过临时表这个概念,一直以为是别的大型数据库软件自带的功能,access好像是没有这个功能的?
索引肯定是建好了的.
之所以想从查询里面取数,是因为,大多数情况下,生成展示报表的时候,都不是直接取用的最原始的表里面的字段,大部分情况下都是需要好几个表好几个字段进行拼接计算之后才生成报表.
每次写sql都去拼表拼字段,有点繁琐所以才想着提前写好一个大的查询表.
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-22 13:20 , Processed in 0.037241 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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