您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

利用ADO技术操作access数据库的方法

2026/2/8 2:19:06发布7次查看
首先我们来介绍下ado对象:
1、access内嵌的vba是用ado技术开发数据库应用的主要工具,ado是目前microsoft通用的数据访问技术;
2、 ado对象模型包括:connection、recordset、record、command、parameter、field、property、stream、error九个对象;
相关推荐:access数据库教程
3、主要的ado对象介绍:
1)connection对象:ado对象模型中的最高级对象,用来实现应用程序与数据源的连接;
2)command对象:主要在vba中使用sql语句访问、查询和修改数据库中的数据,实现recordset对象无法实现的操作(数据表级别的操作),可以使用docmd代替;
3)recordset对象:ado最为常用的、重要的对象,可以访问表和查询对象,返回的记录储存在recorderset对象中,主要执行的操作:
     ①查询数据表中的数据;
     ②在数据表中添加数据;
     ③更新数据表中的数据;
     ④删除数据表中的特定数据;
在access中引用ado对象
1、access引用ado的步骤:
     ①声明、初始化connection对象;
     ②创建recordset对象,编程完成各种操作;
     ③关闭ado对象;
2、声明、初始化connection对象
'声明connection对象:一般使用cn做为变量的命名前缀;
dim coname as adodb.connection
'初始化connection对象,连接当前数据库;
set cnname = currentproject.connection
3、声明和打开recordset对象
1)声明、初始化recordset对象
dim rsname as adodb.recoresetset rsname = new adodb.recordset
2)打开一个recordset对象
使用recordset的open方法可以打开数据表、查询对象、或直接引用sql查询语句
rsname.open source, activeconnection, cursortype,locktype,option
4、关闭recordset和connection对象
rsname.closecnname.closeset rsname = nothingset cnname = nothing
通过recordset对象引用记录字段
1、引用字段的方法有2种:直接在记录集对象中引用字段名称;使用记录集对象的fields(n)属性引用;
code = rsname!字段名
'引用该字段的第一条记录
code = rsname .field(n)
'引用该字段的第n条记录,n从0开始,可以用循环输出需要量的记录
2、如果记录集字段包含空格、或者是一个保留字,则引用时必须将该字段用 [ ] 括起来;
通过recordset对象浏览记录
1.recordset记录集对象提供了4种方法浏览记录
2、 bof、eof属性分别记录指针是否在文件开始、文件末尾;
如果记录集指针指向某记录时,bof和eof都为false;
'添加一个窗体部件的按钮事件:浏览下一条记录
priavte sub comomndnext_click() rsdemo.movenext if rsdemo。eof then rsdemo.movefirst end ifend sub
3、recordset对象的locktype属性默认为adlockreadonly(只读)
通过recordset对象编辑数据
1、用addnew方法添加记录
1)调用记录集addnew方法,产生一个空记录
2)为空记录的各个字段赋值;
3)用记录集update方法更新保持新记录;
'添加记录按钮事件,假设rsdemo记录集有字段id(int),name(string),age(int)
private sub commandadd_click() rsdemo.movelast '记录集指针移动到记录集最后 rsdemo.addnew '添加一条新纪录 rsdemo ! id = "123" rsdemo ! name = "assad" rsdemo ! age = "18" rsdemo.updateend sub
2、用update方法修改记录
1)寻找并将记录集指针移动到需要修改的记录上;
2)对记录中的各个字段的值进行修改;
3)用记录集update方法更新保持新记录;
'修改记录集中age字段所有值+1;
private sub updateage() rsdemo.movefirst do dim code as integer code = rsdemo ! age rsdemo ! age = code +1 loop until rsdemo.eof rsdemo.updateend sub
3、用delete方法删除记录
1)将记录集指针移动到需要删除的记录上;
2)使用delete方法删除当前记录;
3)将某条记录指定为当前记录
'删除rsdemo数据集中age = "18" 的记录private sub deleteage(dim deleteage as integer) rsdemo.movefirst do if rsdemo ! age == deleteage then rsdemo。delete rsdemo。movenext end if loop until rsdemo.eofend sub
注: 一条记录被删除后,access不会自动是下一条记录成为当前记录,这时要用movenext方法将记录集指针定位到最后一条记录中;
通过command/docmd对象使用sql命令
access提供了docmd对象,其runsol方法可以在vba中使用sql命令;
docmd.runsql "sql命令"
or:
dim s as string s = "sql命令" docmd.runsql s
1、定义数据
1)创建数据表
格式: create table 表名 (字段名 数据类型.....)
如:docmd.runsql "create table 研究生(姓名 text(6),年龄 byte,入学日期 date)"
2)增加字段
格式: alter table 表名 add 字段名 数据类型
如:docmd.runsql "alter table student add 学费 currency"
3)改变字段类型
格式: alter table 表名 alter 字段名 新数据类型
如:docmd.runsql "alter table student alter 年龄 integer"
4)改变字段宽度
格式: alter table 表名 alter 字段名 新宽度
如:docmd.runsql "alter table studnt alter 姓名 text(6)"
5)删除一个字段
格式: alter 表名 drop 字段名
如: docmd.runsql "alter student drop 年龄"
6)删除一个数据表
格式: drop table 表名
如:docmd.runsql "drop table student"
7)修改数据表名字
格式: docmd.rename "新表名", actable, "旧表名"
如:docmd.rename "学生", actable, "student"
2、编辑数据
1)向表中追加数据
格式: insert into 表名 values(记录.....)
注: 字符串型数据用 ‘ ’, 日期型型数据可以 ‘ ’,或 # #;
如:docmd.runsql "insert into student values('李达',35,'2003-1-15') "
或:
dim name as stringdim age as byte, dates as date name = inputbox("输入学生姓名") dates = inputbox("输入入学日期") ages = 17 docmd.runsql "insert into student values ('" & name & "'," & age & ",'" & dates & "')"
2)修改表中记录
格式: update 表名 set 字段=数值 where 限定条件
如:docmd.runsql "update student set 年龄=20 where 姓名='李达'"
3)删除待定记录
格式: delete from 表名 where 限定条件
如: docmd.runsql "delete from student where 姓名='李达'"
3、实现数据完整性约束
1)设置主键
格式: alter table 表名 add primary key (字段名)
如:docmd.runsql "alter table 导师 add primary key (导师编号)"
2)设置外键
格式: alter table 主表名 add foreign key (字段名) references 从表名
如:docmd.runsql "alter table 研究生 add foreign key (导师编号) references 导师"
4、执行查询操作
vba程序中可以用sql命令完成数据查询操作,但是无法直接将查询结果所返回的记录集按数据表的形式显示,解决方法有:
1)将查询结果的返回记录集生成一个新表保存在数据库中,然后用ado记录集对象对这个表进行各种操作,完成后再删除这个表;
docmd.runsql "select 姓名,职称,年龄 into temp from 导师 where 职称 in('教授','副教授')"
操作.....
rsteacher.close docmd.runsql "drop table temp"
2)将返回的记录集看成保存在内存中的一个临时表,用ado记录集对象直接打开该查询指令;
访问当前数据库以外的数据库
1、access提供了connection.open方法以连接另一个数据库
2、格式: connection对象.open provider=提供者;date source=数据库名;user id=用户;password=密码
3、其中提供者为 microsoft.jet.oleddb.4.0;数据库名包括 数据库所在的路径(包括.mdb文件名)。
以上就是利用ado技术操作access数据库的方法的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product