全部展开
引用前辈学习的资料,通俗易懂,不忍删章,引用323131愚人节236313431303231363533 e 4b 893 e 5b 19e 313262373935子:
Access数据库与ADODB编程初探
但是,因为我了解这些数据库的基本概念,所以我只介绍VB中的数据库编程
首先有需要注意的事情。 数据库的使用与我们以前使用的文本文件不同。 例如,使用文本文件记录各种有用的数据。 那么,大致有以下:个步骤
读取文件---格式化数据---关闭文件--- -使用数据
如果数据量大,需要过滤,并且存储数据的源文件可能偶尔发生更改,可以使用临时文件存储有用的数据
这将大大提高程序的效率。 要设置“数据格式”,必须首先进行过滤,然后进行分类
这样,文件中的字符串就会转换为对程序使用有用的信息。 这样,处理速度当然会大幅下降
另外,即使设计的数据格式很科学,但如果数据量非常大,文件的容量就会发生变化,普通计算机无法承受
数据库对文本文件的使用也大致分为以下:
打开数据库---查找数据--- -使用数据--- -关闭数据库
由此可见,数据库本身在保存数据时,会以一定的格式保存,因此格式化数据的步骤变少了
其次,数据库和文本文件返回数据的方法不同。如果把文本文件比作一个Textbox,
数据库就像ListBox。 使用文本文件时,必须从整个Textbox中检索有用的信息
进行处理,Listbox可以根据需要返回特定的项目。
因为VB本身没有可以访问数据库的类,所以要使用数据库,必须引用可以访问数据库的类。
这里采用了ADODB。 比可以访问DAO和数据库的API更灵活、更强大。 比API更容易使用,适合初学者。
另一方面,Access数据库比SQL简单很多,可以满足中小型APP应用程序的需要,因此在使用数据库时选择了Access。
必须首先设计数据结构,以便使用文本文件存储数据。 但是,在设计Access数据库的结构时,
为了制定详细的计划,需要使用其他程序。 推荐的程序是office访问或VB附带的vis数据。
数据库设计完成后,可以开始“数据库编程”
首先,需要引用ADO . 具体方法是在“工程”--“引用”中找到“microsoftactivexdataobject *.* library”,
其中的“*.*”是指ADO的版本号,通常APP应用程序和ActiveX控件向后兼容,因此尽可能选择新版本。
使程序在识别旧版本的Access的同时,也能够识别更高版本的Access。
接下来,需要在程序中创建对象。 您只需创建一个ADO对象,以便可以将FileBox添加到窗体中并查看文件名
允许访问数据库。 有两个常用对象。 是连接和记录集
创建这两个对象的具体方法是:
1 .引用后,使用如下New关键字
privateconnasnewadodb.connection
privaterecoasnewadodb.recordset
2 .如果没有引用,则在CreateObject中创建对象:
DimConn,Reco
set conn=createobject (adodb.connection ) )。
set reco=createobject (adodb.recordset ) )。
创建对象后,下一步是打开数据库
首先,您可以查看以下代码以成功打开数据库
conn.open ' provider=Microsoft.jet.oledb.4.0; DataSource=D:Main.mdb '
此代码打开了一个名为Main.mdb的d驱动器数据库
Connection.Open方法的第一个参数是连接代码,传递给系统的数据库引擎。 上半场' provider=Microsoft.jet.oledb.4.0 ',
这表示数据库的类型。 根据数据库的不同可能会有所不同。 后半部分的“Source=d:main.mdb”表示数据库所在的绝对路径。
打开数据库后,还会打开表。 如果数据库中有名为“Users”的表,则字段为用户名和密码两个。 请看下面的代码。
1 .我想回“用户”,“用户名”是“去年烟花”的“密码”
Recordset.open'Select密码FromUsersWhere用户名='去年烟火'',Connection,1,1
然后,可以比较用户输入的密码,以查看是否允许登录。
if recordset.eofandrecordset.BOF then
Msgbox"用户不存在!",16Else
IfPassWord=Recordset("密码").valuethen
msgbox"登录成功!",64
Else
msgbox"密码错误!",32
EndIf
EndIf
Recordset.Close
2.假设Admin已经成功登录系统,我们想把所有的用户名和密码都显示出来
Recordset.open"Select*FromUsers",Connection,1,1
这时,表已经被打开,我们就用以下代码把它显示出来.
DowhlieNotRecordset.eof
Print"用户名:"&Recordset("用户名").value&"密码:"&Recordset("密码").value
Recordset.MoveNext
Loop
Recordset.Close
由以上代码示例可以看出,打开表时,可以只打开其中的一个字段,也可以打开所有.第一个参数是SQL语句.
Select[字段名]From表名[Where条件]
这里的条件可以省略.且字段名也可以用"*"来代替所有字段.
需要注意的是,如果你用(1)中的方法打开,那么(2)后面显示的代码就不能再用在(1)中.因为(1)里并没有打开[用户名]字段,
所以这一句Recordset("密码")就没有值存在,还有可能出错.
后面的条件,可以用"="、">"、"32".(这里假设[ID]为数字型.)
这是打开的部分.第二个很重要的部分就是查询记录.
数据库它并不是把所有记录全部放到一个变量中备用的.而是以"当前记录"的形式来返回一个值.所以我们想从中找到有用的信息,
就必须要对信息进行定位/筛选.
定位:
移动到下一条Recordset.MoveNext
移动到上一条Recordset.MovePrevious
移动到最后一条Recordset.MoveLast
移动到第一条Recordset.MoveFrist
移动到某一条Recordset.MoveNumber
筛选:
Recordset.Find"条件"
如:[用方法(2)打开表之后]
PrivateSubCommand1_Click()
Recordset.Find"用户名="&"text1.text"
IfRecordset.Eof<>TrueThen
Msgbox"该用户的密码是:"&Recordset("密码").value,64
Else
Msgbox"未找到该用户的资料!",16
EndIf
EndSub
MoveNext只有当Eof不为True时,才可用,否则发生错误.而MovePrevious刚是Bof不为True时....
而只要Eof和Bof中有一个不为真时,也就是说只要有一条记录时,它就可以使用.
Find方法中的条件和Open时的第一个参数中的条件表述方法是完全一致的.当在已打开的记录集中,找不到该记录时,Eof为True.
找到则当前的值就是符合条件的记录.
第三个部分就是添加/修改/删除记录.
修改记录很简单,先按以上的方法找到相关记录之后,给记录赋值就可以了.
比如:[(修改密码)按方法(1)打开表之后]
Recordset("密码").value="123456"
Recordset.Updata
需要注意的就是,在修改完成后,要调用Updata方法,这样修改才能生效.
而添加记录则可以用以下代码来实现:
Recordset.addnew
Recordset("用户名").value="Admin"
Recordset("密码").value="Admin"
Recordset.Updata
删除记录:
Recordset.delete
Recordset.uptata
这里,先要调用Addnew方法,增加一条新记录,然后对这个新记录中的各字段赋值,最后再调用Updata方法.
到这里就差不多了,最后说一下上面提到的几个方法.
Recordset.OpenSQL语句,数据源,游标类型,打开方法
SQL语句不用说了,就是Select那啥的,目的就是按要求从表中返回数据
数据源就是一个打开之后的Connection对象.
去他妈的游标类型,填1(即openkeyset)就可以了[偷笑ing]
打开方法对应了几个常数,具体哪几个可以从对象浏览器里看.
对应数值的意义:
1只读2独占3可写4自已可写,别人可读
Connection.open连接代码,服务器用户名,密码
已赞过
已踩过<
你对这个回答的评价是?
评论
收起