
Microsoft Office Access是由微软发布的关系数据库管理系统。它结合了 MicrosoftJet Database Engine 和 图形用户界面两项特点,是 Microsoft Office 的系统程序之一。用vba代码将access数据库连接求代码,代码如下:
Sub FYMXDL()
Dim XQID As Integer
Dim JZID As Integer
Dim FYID As Integer
Dim FBXZ As String '分包性质
Dim DW As String
Dim SARR(1 To 31) As Double
Dim rst As New ADODB.Recordset
mYpath = ThisWorkbook.Path &"\jzfydata.accdb"
Set cONn = CreateObject("ADODB.Connection")
cONn.ConnectionString = "Provider=Microsoft.Ace.OleDB.12.0Data Source=" &mYpath
cONn.ConnectionString = cONn.ConnectionString &"Jet OLEDB:Database "
cONn.Open
XQID = Cells(3, 2).Value
JZID = Cells(3, 5).Value
'清空改小区-建筑的费用明细
Sql = "delete from fymxb where 小区ID=" &XQID &" AND 建筑ID = " &JZID
cONn.Execute Sql
Const kshh = 7
hh = kshh
Do While Cells(hh, 3).Value >0
FYID = Cells(hh, 3).Value
FBXZ = Cells(hh, 11).Text
For i = 1 To 31
SARR(i) = Round(Cells(hh, 13 + i - 1).Value, 2)
Next i
Sql = Sql &"," &SARR(i)
Next i
Sql = Sql &" )"
cONn.Execute Sql
hh = hh + 1
Loop
End Sub
方法如下:假设数据库均为Access文件:
ThisWorkbook.Path &"\数据库1.accdb"
ThisWorkbook.Path &"\数据库2.accdb"
cnn.Open "Provider=Microsoft.ACE.OLEDB.12.0Data Source=" &ThisWorkbook.Path &"\数据库1.accdb"
对于非连接数据库数据库2,数据表前面需要加上数据库全名:
[MS Accesspwd=密码Database=" &ThisWorkbook.Path &"\数据库2.accdb].数据表名
EXCEL vba 数据库连接
听语音
原创
|
浏览:7393
|
更新:2016-06-23 16:12
|
标签:EXCEL VBA
1
请点击输入图片描述
2
请点击输入图片描述
3
请点击输入图片描述
4
请点击输入图片描述
5
请点击输入图片描述
分步阅读
vba可以连接数据库并获取数据库的信息进行显示。
工具/原料
EXCEL2007
方法/步骤
1
首先在开发工具选项卡中插入一个表单控件(按钮)。
请点击输入图片描述
2
拖拽出按钮后会d出指定宏的窗口,这里我们新建宏。
请点击输入图片描述
3
新建按钮单击后,进入模块代码编辑界面,这里开始编辑代码。
请点击输入图片描述
4
如图,代码已经编辑好了,这里为大家解析一下代码的功能:
Dim cn As Object '定义数据链接对象 ,保存连接数据库信息
Dim rs As Object '定义记录集对象,保存数据表
Set cn = CreateObject("ADODB.Connection") '创建数据链接对象
Set rs = CreateObject("ADODB.RecordSet") '创建记录集对象,用于接收数据查询获得的结果集
Dim strCn As String, strSQL As String '字符串变量
strCn = "Provider=sqloledbServer=(local)Database=yourdatabasenameUid=saPwd=yourpassword" '定义数据库链接字符串
strSQL = "select bookname,price,author from book" '设置SQL语句
cn.Open strCn '打开连接
rs.Open strSQL, cn‘读取数据库中的数据
Dim i As Integer, j As Integer, sht As Worksheet 'i,j为整数变量;sht 为excel工作表对象变量,指向某一工作表
Set sht = ThisWorkbook.Worksheets("sheet1")
’循环读取数据并将数据显示到excel中
Do While Not rs.EOF '当数据指针未移到记录集末尾时,循环下列 *** 作
sht.Cells(i, 1) = rs("bookname") '把当前记录的字段1的值保存到sheet1工作表的第i行第1列
sht.Cells(i, 2) = rs("price") '把当前字段2的值保存到sheet1工作表的第i行第2列
sht.Cells(i, 3) = rs("author") '把当前字段2的值保存到sheet1工作表的第i行第2列
rs.MoveNext '把指针移向下一条记录
i = i + 1 'i加1,准备把下一记录相关字段的值保存到工作表的下一行
Loop '循环
rs.Close '关闭记录集,至此,程序将把某数据表的字段1和字段2保存在excel工作表sheet1的第1、2列,行数等于数据表的记录数
5
执行结果与数据库中结果对比
请点击输入图片描述
请点击输入图片描述
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)