当前位置:首页 » 数据仓库 » vbaado连接access数据库
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

vbaado连接access数据库

发布时间: 2022-05-18 02:25:22

① vba 通过ado 连接access

应该可以呀 连接的方法 跟vb连接数据库一模一样

一个例子

(前提:添加ADO 控件)

Dim Conn As ADODB.Connection
Dim Rst2 As ADODB.Recordset
Set Conn = CurrentProject.Connection
Set Rst2 = New ADODB.Recordset
Rst2.Open "sql语句", Conn, adOpenForwardOnly, adLockReadOnly
If Rst2.EOF Then
MsgBox ("NO")
Exit Sub
End If

② 利用 vba连接access数据库 完成 这个问题

接和断开 两种, 登陆时间的计算方法 是断开的时间 减去 连接的时间 但是要注意 状态上有出现里面有专门的网建优化和seo交流地。每周还有别处没有的电影和免费资源。网站“ 我们爱小众 ”有话大声说,有爱尽情秀 小众心灵之地,你的圈子才知你的心

③ 如何用vba将ACCESS窗体和查询导入另一个数据库中

Access是微软Office组件的数据库软件,使用它可以进行简单的数据库软件的开发。但Access的图表功能和数据分析功能不如Excel强大,常用的做法可以将Access中的数据导入Excel中再进行处理。
代码利用ADO组件可以方便地对各种数据进行连接和访问。ADO组件中的Connection对象可以实现对数据库的连接,并可以快速实现SQL语句的执行,然后再用VBA将SQL查询的结果输出到Excel表格中。
打开VBE窗口,选择菜单“工具”一“引用”,勾选MicrosoftActiveXDataObjects2.8Library,并单击“确定”按钮。
利用ADO连接数据库ADO的全称是ActiveXDataObject,是一个用于存取数据源的COM组件,用以快速实现各种数据库的连接、读取、写入。在ADO组件中有一个Connection对象,利用Connection对象的Open方法可以实现数据库的连接。

④ 如何在VBA中用ADO连接远程的access数据库

远程连接access数据库的几个方法:
1.建立VPN(Virtual Private Network),然后把服务器中mdb文件所在的 Folder 共享即可。连接方法如下:
“Provider=Microsoft.Jet.OLEDB.4.0;Data Source=\\服务器名\\文件夹 \\mydata.mdb;Jet
OLEDB:Database Password=datapass;Persist Security Info=False”
2.把数据库放在Web 服务器上,使ADO或RDO通过RDS(Remote Data Service) 及IIS来实现:
如果服务器设置了ODBC DSN的话,连接方法如下:
"Provider=MS Remote;Remote Server=http://服务器名;Remote Provider=MSDASQL;DSN=AdvWorks;Uid=dataUserName;Pwd=dataPassWord"
如果设置的是OLE DB Provider 的话,连接方法如下:
"Provider=MS Remote;Remote Server=http://服务器名;Remote
Provider=Microsoft.Jet.OLEDB.4.0; Data Source=数据库文件路径,"+ "admin,"+"" (数据库用户名为:admin;密码为空)
3.编写服务器程序,通过TCP/IP,传递Recordset。
4.使用第三方控件,如:ADO Anywhere或UDAParts RDB等。
5.使用XMLHTTP

应用举例
OledbConnection myconn = null;
myconn = new OledbConnection("192.168.1.155", "DSN=mydata;DRIVER={Microsoft Access Driver (*.mdb)};UID=test;PWD=test;"); //其中服务器IP是 192.168.1.155 ;数据库名是 mydata ;数据库用户名这密码都是test myconn.Open();

⑤ excel vba ADO 如何远程连接,比如说连接局域网其它电脑上的access数据库。请给出代码

例如;远程SQLSERVER

连接字符串为:

Provider=SQLOLEDB.1;Password=密码;Persist Security Info=True;User ID=用户名;Initial Catalog=数据库名称Data Source=远程主机IP

⑥ 在EXCEL VBA的基础上,怎样通过ADO将ACCESS数据库A中的表a导入到另外一个ACCESSS数据库B中呢

使用ADO运行Insert 语句,一条条插入到Access或许可行吧。不过貌似将数据从mdbA.tableA读入处理后生成SheetB,然后再mdbB中读入SheetB比较省事吧,那要看你的应用是怎样的了。貌似,Excel增强集工具有个“连结外部数据”的功能,要不楼主找找看吧

⑦ VBA Excel里 用ADO访问ACCESS数据库的问题

rst.OpenSql,cn.ConnectionString

我的数据库语言不是很好,但看了你的代码,也觉得很乱,你的代码至少有好几种方法可以修改,上面是最简单的一种,实际上你的数据库在acapp.OpenCurrentDatabase的时候已经打开了,接下来根本就不需要再次使用cn进行连接。

所以第二种改法是:

acApp.OpenCurrentDatabase(dbPath)
'DimcnAsADODB.Connection'不需要再次连接
'Setcn=acApp.CurrentProject.Connection'不需要再次连接
DimrstAsADODB.Recordset
Setrst=NewADODB.Recordset
DimSqlAsString
Sql="Select*From0012X32"
rst.OpenSql,acApp.ADOConnectString'我只需要在这里调用连接的数据就可以了,而这个连接数据存储在acApp.ADOConnectString里面。
rst.MoveFirst

下面是RecordSet的OPEN的用法:

Open方法(ADORecordset)
打开游标。
语法
recordset.OpenSource,ActiveConnection,CursorType,LockType,Options
参数
Source可选。Variant,计算有效的Command对象、SQL语句、表名、存储过程调用、URL或包含持久存储Recordset的文件名或Stream对象。
ActiveConnection可选。Variant,计算有效的Connection对象变量名,或包含ConnectionString参数的String。
CursorType可选。CursorTypeEnum值,确定在打开Recordset时提供者应使用的游标类型。默认值为adOpenForwardOnly。
LockType可选。LockTypeEnum值,确定在打开Recordset时提供者应使用的锁定(并发)类型。默认值为adLockReadOnly。
Options可选。Long值,指示提供者计算Source参数的方式(如果该参数表示除Command对象之外的某些内容),或者指示Recordset应该从以前保存过的文件中恢复。可以是一个或多个CommandTypeEnum或ExecuteOptionEnum值,这些值可以用位AND操作符组合。
注意如果从包含持久Recordset的Stream中打开Recordset,那么使用adAsyncFetchNonBlocking的ExecuteOptionEnum值将不起作用;提取操作将同步进行并发生阻塞。adExecuteNoRecords或adExecuteStream的ExecuteOpenEnum值不应与Open一起使用。

因为ADO语言,直接提供了连接数据库的方法,所以我们可以直接这样来连接数据库:(算作本题的第三种改法吧)

DimcnAsNewADODB.Connection'直接创建对数据库连接的实例对象cn
cn.Open"Provider=Microsoft.Jet.OLEDB.4.0;DataSource="&dbPath'连接数据库
DimrstAsNewADODB.Recordset
DimSqlAsString
Sql="Select*From0012X32"
rst.OpenSql,cn
rst.MoveFirst
rst.Move(1)
MsgBoxrst.Fields(1).Value

⑧ 关于EXCEL VBA 用ADO连接ACCESS数据库的问题,重谢!

没加入数据库的引用,ALT+F11加入你的Microsoft Access 所用的引用就没问题了

⑨ 如何用vba代码将access数据库连接求代码

>>.用vba连接ACESS:
Set Conn= Server.CreateObject("ADODB.Connection")
Conn.ConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath("sample.mdb")
Conn.Open

>>.用vba连接EXCEL,打开EXCEL记录集:
Set connExcel = Server.CreateObject("ADODB.Connection")
connStr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath( "InputExcel\sample.xls") &";Extended Properties='Excel 8.0;HDR=YES;IMEX=1';"
connExcel.Open connStr
Set rs = Server.CreateObject("ADODB.Recordset")
rs.Open "Select * From [sheet1$]", connExcel, 0, 1

>>.vba数据处理[转载]:
===============================================
用Excel+VBA+SQL Server进行数据处理

使用Excel+VBA+SQL Server进行数据处理是一种简单有效方法,掌握以下基础知识实现快速入门(掌握excel/vba/sqlserver各1%内容,你就能成为数据处理高手的:)):

一、Excel基础知识
了解工作簿(Workbook)、工作表(Worksheet)、单元格(Cell)等的基本概念,熟悉一些基本操作。

二、SQL Server基础知识
参见
1、数据库有关概念:数据库、表、记录、字段
A)数据库(Database)
B)表(Table)、记录(行,Row,Record)、字段(列,Column,Field)...

2、常见数据操作的SQL命令:select, insert , update ,delete

三、VBA基础知识:
1、基本概念。
2、基本控制结构:
·顺序结构:程序按顺序执行;
·分支结构命令:

if 条件 then
<如果条件成立执行本语句块>
end if

或:

if ... then
...
else
...
end if

或:

if ... then
...
elseif ...
...
else
...
end if
等。。

·循环结构命令:

for i=? to ??
...
next



do while ...
...
loop

3、在VBA中操纵对象,先理解操纵EXCEL工作表和数据库对象:

将值写入EXCEL单元格,如:thisworkbook.worksheets("sheet1").cells(1,2)=1234444

从EXCEL单元格取得数值,如:x=thisworkbook.worksheets("sheet1").cells(1,2)

数据库操作:

cn.open ...(建立数据连接对象)
rs.open ... (建立数据集对象)
x=rs("...") (读取数值)
rs.close (关闭rs)
cn.close (关闭cn)

cn.execute (执行sql语句)

...

四、例子

sub test() '定义过程名称
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=sqloledb;Server=服务器名称或IP地址;Database=数据库名称;Uid=用户登录名;Pwd=密码;" '定义数据库链接字符串

'下面的语句将读取数据表数据,并将它保存到excel工作表中:画两张表想象一下,工作表为一张两维表,记录集也是一张两维表
strSQL = "select 字段1,字段2 from 表名称" '定义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") '把当前记录的字段1的值保存到sheet1工作表的第i行第1列
sht.Cells(i, 2) = rs("字段2") '把当前字段2的值保存到sheet1工作表的第i行第2列
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=5 to 500 '循环开始,i从5到500
strSQL=strSQL & "insert into 表名(字段) values(" & sht.cells(i,8)*sht.cells(i,9) & ") ;" '构造SQL命令串
next
'至此生成一串SQL命令串,保存的内容大概为:insert into 表名(字段) values(数值1);insert into 表名(字段) values(数值2);...
cn.execute strSQL '执行该SQL命令串,如果SQL命令没有错误,将在数据库中添加501个记录;也可以用rs.open strSQL,cn 执行
cn.close '关闭数据库链接,释放资源
end sub

=====================================

>>.听说可以用一条语句实现记录集导入excel表,而且不是用循环的,不知道是真是假,等待高手的回答。