设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 2329|回复: 8
打印 上一主题 下一主题

[ADO/DAO] 【求助】如何从Excel里提取数据并加入ACCESS里?

[复制链接]
跳转到指定楼层
1#
发表于 2008-10-6 16:59:49 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
为了方便输入一些批量数据,我想在Excel里输入一批数据,然后把这些数据添加到ACCESS里的特定表里,但最好在添加时不用打开ACCESS程序,请问如何编写代码?

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享分享 分享淘帖 订阅订阅
2#
发表于 2008-10-7 01:58:17 | 只看该作者
如果不想打开access数据库,建议用ado执行增加到acc数据库的操作。
3#
 楼主| 发表于 2008-10-7 08:38:49 | 只看该作者
我知道是用ado执行操作,关键问题是不知如何编写代码?所以向各位请教,呵呵[:34]
4#
发表于 2008-10-7 09:33:51 | 只看该作者
分步进行:
先分别尝试实现以下步骤
1、读取Excel创建记录集
2、将记录集写入Access
5#
 楼主| 发表于 2008-10-7 10:20:44 | 只看该作者
我编写了以下代码,但运行时总是出现错误,错误提示如附件!还请高手帮忙看一下,问题出在哪里?
*********************************
Sub 添加() '定义过程名称
Dim i As Integer, j As Integer, sht As Worksheet 'i,j为整数变量;sht 为excel工作表对象变量,指向某一工作表
Dim cn As New ADODB.Connection '定义数据链接对象 ,保存连接数据库信息;请先添加ADO引用
Dim rs As New ADODB.Recordset '定义记录集对象,保存数据表
Dim strCn As String, strSQL As String '字符串变量

strCn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\示例\订单数据库.mdb" '定义数据库链接字符串

'下面的语句将读取数据表数据,并将它保存到excel工作表中:画两张表想像一下,工作表为一张两维表,记录集也是一张两维表
strSQL = "select 客户代码,订单号码,订单日期 from dingdanbiao" '定义SQL查询命令字符串
cn.Open strCn '与数据库建立连接,如果成功,返回连接对象cn
rs.Open strSQL, cn '执行strSQL所含的SQL命令,结果保存在rs记录集对象中
i = 1
Set sht = ThisWorkbook.Worksheets("sheet1") '把sht指向当前工作簿的sheet1工作表
Do While Not rs.EOF '当数据指针未移到记录集末尾时,循环下列操作
sht.Cells(i, 1) = rs("客户代码") '把当前记录的字段1的值保存到sheet1工作表的第i行第1列
sht.Cells(i, 2) = rs("订单号码") '把当前字段2的值保存到sheet1工作表的第i行第2列
sht.Cells(i, 3) = rs("订单日期")
rs.MoveNext '把指针移向下一条记录
i = i + 1 'i加1,准备把下一记录相关字段的值保存到工作表的下一行
Loop '循环
rs.Close '关闭记录集,至此,程序将把某数据表的字段1和字段2保存在excel工作表sheet1的第1、2列,行数等于数据表的记录数
'下面的语句将读取excel工作表数据,并将之简单计算后存入数据库,这里使用上面程序中的一些变量
'假设分别读取工作表sheet1第5行至第500行的第8列和第9列已存在的数据,然后将它们相乘,并将积存入数据库的某个表
strSQL = "" '清空上面定义的变量
For i = 2 To 3 '循环开始,i从2到3
strSQL = strSQL & "insert into dingdanbiao(客户代码,订单号码,订单日期) values(" & sht.Cells(i, 1) & "," & sht.Cells(i, 2) & "," & sht.Cells(i, 3) & ";)"  '构造SQL命令串

Next
'至此生成一串SQL命令串,保存的内容大概为:insert into 表名(字段) values(数值1);insert into 表名(字段) values(数值2);...
cn.Execute (strSQL) '执行该SQL命令串,如果SQL命令没有错误,将在数据库中添加501个记录;也可以用rs.open strSQL,cn 执行
'cn.Update
cn.Close '关闭数据库链接,释放资源
MsgBox "添加成功", vbInformation, ""
End Sub

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
6#
发表于 2008-10-7 11:01:13 | 只看该作者
做了一个示例,参考参考。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
7#
 楼主| 发表于 2008-10-7 11:24:03 | 只看该作者
OK,了解,谢谢!再研究一下!
8#
发表于 2010-10-22 12:56:00 | 只看该作者
学习学习
9#
发表于 2010-10-22 12:02:38 | 只看该作者
下来学习下,和自己做的程序比较比较
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-5-10 12:46 , Processed in 0.098841 second(s), 33 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

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