首页 > 编程知识 正文

vbnet连接sql数据库实例(如何建立vb和sql数据库连接)

时间:2023-05-06 03:19:30 阅读:65083 作者:4045

全部展开

引用前辈学习的资料,通俗易懂,不忍删章,引用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"用户不存在!",16

Else

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连接代码,服务器用户名,密码

已赞过

已踩过<

你对这个回答的评价是?

评论

收起

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。