数据库
首页 > 数据库> > VBA链接数据库

VBA链接数据库

作者:互联网

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=sqloledb;Server=本地数据库的名称;Database=数据库名;Integrated Security=SSPI;Persist Security Info=False;"

'定义远程数据库链接字符串
strCn = "Provider=sqloledb;Data Source=远程数据库的IP地址;Initial Catalog=数据库名;User ID=登陆名;Password=密码;Persist Security Info=False;"

strSQL = "select * from TUTORIALS_TBL" '设置SQL语句
CN.Open strCn '打开连接
rs.Open strSQL, CN '读取数据库中的数据

Dim i As Integer, sht As Worksheet 'i,j为整数变量;sht 为excel工作表对象变量,指向某一工作表
i = 1
Set sht = ThisWorkbook.Worksheets("sheet1")
'循环读取数据并将数据显示到excel中
For j = 0 To rs.Fields.Count - 1
sht.Cells(1, j + 1).Value = rs.Fields(j).Name
Next j
Range("A2").CopyFromRecordset rs
~~~
'Do While Not rs.EOF '当数据指针未移到记录集末尾时,循环下列操作
'
' sht.Cells(i, 1) = rs("A") '把当前记录的字段1的值保存到sheet1工作表的第i行第1列
'
' sht.Cells(i, 2) = rs("B") '把当前字段2的值保存到sheet1工作表的第i行第2列
'
' sht.Cells(i, 3) = rs("C") '把当前字段2的值保存到sheet1工作表的第i行第2列
'
' sht.Cells(i, 4) = rs("D") '把当前字段2的值保存到sheet1工作表的第i行第2列
'
' rs.MoveNext '把指针移向下一条记录
'
' i = i + 1 'i加1,准备把下一记录相关字段的值保存到工作表的下一行
'
'Loop '循环
~~~
rs.Close '关闭记录集,至此,程序将把某数据表的字段1和字段2保存在excel工作表sheet1的第1、2列,行数等于数据表的记录数

标签:VBA,sht,rs,数据库,Cells,sheet1,链接
来源: https://www.cnblogs.com/cyz-2020/p/15624812.html