ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[转帖] VB把access数据库里的表导出成EXCEL表

[复制链接]

TA的精华主题

TA的得分主题

发表于 2011-7-23 16:49 | 显示全部楼层 |阅读模式
本帖最后由 lzqlaj 于 2011-10-6 10:21 编辑

转帖自: http://blog.csdn.net/zoomwe/article/details/2752618(本人已通过测试)。以下为原网页文内容未作修改:
新建一个窗体,窗体上就放一个Command1按钮 ,操作:点一下Command1就导出完成了,在网上找了很久,结果在美国的一个代码论坛上找到的,国内难道都没有人这样写过吗?
注意点:在D盘下要存在一个数据库名为data.mdb  ,这个数据库里要包含一个叫pop的表,至于表里边什么内容,就随便填一点就可以了。
下面是代码了:
Private Sub Command1_Click()
    Call ExportOneTable
End Sub
Private Sub ExportOneTable()
'EXPORTS TABLE IN ACCESS DATABASE TO EXCEL
'REFERENCE TO DAO IS REQUIRED
    Dim strExcelFile As String
    Dim strWorksheet As String
    Dim strDB As String
    Dim strTable As String
    Dim objDB As Database
    'Change Based on your needs, or use
    'as parameters to the sub
    strExcelFile = "d:/MySpreadSheet.xls"
    strWorksheet = "WorkSheet1"
    strDB = "d:/Data.mdb"
    strTable = "pop"
    Set objDB = OpenDatabase(strDB)
    'If excel file already exists, you can delete it here
    If Dir(strExcelFile) <> "" Then Kill strExcelFile
    objDB.Execute _
            "SELECT * INTO [Excel 8.0;DATABASE=" & strExcelFile & _
                                                 "].[" & strWorksheet & "] FROM " & "[" & strTable & "]"
    objDB.Close
    Set objDB = Nothing
    MsgBox  OK
End Sub

其它帖子:
成绩录入工具(vb)
http://club.excelhome.net/thread-744536-1-1.html
空行操作(“插入空行”)
http://club.excelhome.net/thread-590404-1-1.html
[分享] (无意中发现的)罗刚君 底端标题生成工具(开放源码含附件)
http://club.excelhome.net/thread-601577-1-1.html
[源码全部公开] 分数段统计(数组)(vba)
http://club.excelhome.net/thread-750450-1-1.html
[源码全部公开] 分数段统计(vba)
http://club.excelhome.net/thread-599282-1-1.html
搜狗文本词库的制作(vb)
http://club.excelhome.net/thread-670925-1-1.html
汉字与区位码转换(vb版)
http://club.excelhome.net/thread-670918-1-1.html
[源码全部公开] 区位码与汉字相互转换
http://club.excelhome.net/thread-601351-1-1.html
优盘禁用工具
http://club.excelhome.net/thread-495008-1-1.html
[源码全部公开] 工资条通用生成程序(也可分考场)
http://club.excelhome.net/thread-487664-1-1.html
[转帖] 把excel追加导入到access数据库
http://club.excelhome.net/thread-745574-1-1.html
[转帖] 删除mbd数据库中所有记录
http://club.excelhome.net/thread-745139-1-1.html
[转帖] VB中对数据库的各种操作
http://club.excelhome.net/thread-745136-1-1.html

TA的精华主题

TA的得分主题

发表于 2011-7-23 21:38 | 显示全部楼层
不知道LZ是不是没找过,还是觉得外国的月亮特别圆。
还以为什么高级东东。不就DAO吗?不就SQL语句导出数据吗?Access中国网里的例子俯拾皆是。一句代码导入导出:
http://www.access-cn.com/thread-93430-1-1.html

TA的精华主题

TA的得分主题

 楼主| 发表于 2011-7-24 11:01 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
原帖由 roych 于 2011-7-23 21:38 发表
不知道LZ是不是没找过,还是觉得外国的月亮特别圆。
还以为什么高级东东。不就DAO吗?不就SQL语句导出数据吗?Access中国网里的例子俯拾皆是。一句代码导入导出:
http://www.access-cn.com/thread-93430-1-1.html

那是原帖子内容与我无关,本人这几天才接触数据库,水平很有限。
导入数据(导入数据时第一行必须是字段名):
DoCmd.RunSQL "INSERT INTO 表名 SELECT * FROM [Excel 8.0;DATABASE=E:\桌面\测试数据.xls].[Sheet1$]"
DoCmd.RunSQL "INSERT INTO 表名 SELECT * FROM [Sheet1$] IN 'E:\桌面\测试数据.xls'[EXCEL 8.0;]"
DoCmd.RunSQL "INSERT INTO 表名 SELECT * FROM [Sheet1$] IN 'E:\桌面\测试数据.xls' 'EXCEL 8.0;'"
导出数据:
DoCmd.RunSQL "SELECT * INTO [Excel 8.0;DATABASE=E:\桌面\测试数据.xls].[Sheet1] FROM 表名"
DoCmd.RunSQL "SELECT * INTO [Sheet1] IN 'E:\桌面\测试数据.xls'[EXCEL 8.0;] FROM 表名"
DoCmd.RunSQL "SELECT * INTO [Sheet1] IN 'E:\桌面\测试数据.xls' 'EXCEL 8.0;' FROM 表名"
能讲一下,具体怎么从mdb导出到excel吗?

TA的精华主题

TA的得分主题

发表于 2011-7-24 13:26 | 显示全部楼层
Docmd.RunSQL语句和Connection.Execute(或Database.Execute)语句是通用的。不同的是,使用前者的话会可能会弹出提示对话框(例如执行删除查询等操作时)。
如果在VB(是VB,不是Access)里使用Docmd,则需要建立Access组件。不过在Access里,我们通常是使用TransferSpeardSheet来处理的,语句没有RunSQL那么复杂。

TA的精华主题

TA的得分主题

发表于 2011-12-23 19:40 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2012-3-11 17:34 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2013-2-2 04:00 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2013-10-9 12:44 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
学习了,谢谢分享!!!

TA的精华主题

TA的得分主题

发表于 2014-12-31 13:46 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-12-23 16:41 , Processed in 0.034402 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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