VB数据库.docx
《VB数据库.docx》由会员分享,可在线阅读,更多相关《VB数据库.docx(43页珍藏版)》请在冰点文库上搜索。
VB数据库
VB数据库编程技术
一ODBC概述
在传统的数据库管理系统中,每个数据库管理系统都有自己的应用程序开发接口(API),为了解决此问题,微软公司开发了ODBC(OpenDataBaseConnectivity,即开放数据库互连)。
ODBC是一套开放数据库系统应用程序接口规范,目前它已成为一种工业标准,它提供了统一的数据库应用编程接口(API),为应用程序提供了一套高层调用接口规范和基于动态连接库的运行支持环境。
使用ODBC开发数据库应用时,应用程序调用的是标准的ODBC函数和SQL语句,屏蔽了DBMS之间的差异,数据库底层操作由各个数据库的驱动程序完成。
因此应用程序有很好的适应性和可移植性,并且具备了同时访问多种数据库管理系统的能力,从而彻底克服了传统数据库应用程序的缺陷。
主要任务包括:
建立与数据源的连接;向数据源发送SQL请求;断开与数据源的连接
数据源
数据源是指任一种可以通过ODBC连接的数据库管理系统,它包括要访问的数据库和数据库的运行平台。
数据源名掩盖了数据库服务器或数据库文件间的差别,通过定义多个数据源,每个数据源指向一个服务器名,就可在应用程序中实现同时访问多个DBMS的目的。
数据源(DataSourceName,简称DSN)是驱动程序与DBS连接的桥梁,数据源不是DBS,而是用于表达一个ODBC驱动程序和DBMS特殊连接的命名。
在连接中,用数据源名来代表用户名、服务器名、所连接的数据库名等,可以将数据源名看成是与一个具体数据库建立的连接。
数据源分为以下三类:
(1)用户数据源:
用户创建的数据源,称为“用户数据源”。
此时只有创建者才能使用,并且只能在所定义的机器上运行。
任何用户都不能使用其他用户创建的用户数据源。
(2)系统数据源:
所有用户和在WindowsNT下以服务方式运行的应用程序均可使用系统数据源。
(3)文件数据源:
文件数据源是ODBC3.0以上版本增加的一种数据源,可用于企业用户,ODBC驱动程序也安装在用户的计算机上。
(与机器无关)
二、SQL语言基础
创建表格
SQL语言中的createtable语句被用来建立新的数据库表格。
Createtable语句的使用格式如下:
createtabletablename
(column1datatype,
column2datatype,
column3datatype);
如果用户希望在建立新表格时规定列的限制条件,可以使用可选的条件选项:
createtabletablename
(column1datatype[constraint],
column2datatype[constraint],
column3datatype[constraint]);
举例如下:
createtableemployee
(firstnamevarchar(15),
lastnamevarchar(20),
agenumber(3),
addressvarchar(30),
cityvarchar(20));
简单来说,创建新表格时,在关键词createtable后面加入所要建立的表格的名称,然后在括号内顺次设定各列的名称,数据类型,以及可选的限制条件等。
注意,所有的SQL语句在结尾处都要使用“;”符号。
使用SQL语句创建的数据库表格和表格中列的名称必须以字母开头,后面可以使用字母,数字或下划线,名称的长度不能超过30个字符。
注意,用户在选择表格名称时不要使用SQL语言中的保留关键词,如select,create,insert等,作为表格或列的名称。
数据类型用来设定某一个具体列中数据的类型。
例如,在姓名列中只能采用varchar或char的数据类型,而不能使用number的数据类型。
SQL语言中较为常用的数据类型为:
char(size):
固定长度字符串,其中括号中的size用来设定字符串的最大长度。
Char类型的最大长度为255字节。
varchar(size):
可变长度字符串,最大长度由size设定。
number(size):
数字类型,其中数字的最大位数由size设定。
Date:
日期类型。
number(size,d):
数字类型,size决定该数字总的最大位数,而d则用于设定该数字在小数点后的位数。
最后,在创建新表格时需要注意的一点就是表格中列的限制条件。
所谓限制条件就是当向特定列输入数据时所必须遵守的规则。
例如,unique这一限制条件要求某一列中不能存在两个值相同的记录,所有记录的值都必须是唯一的。
除unique之外,较为常用的列的限制条件还包括notnull和primarykey等。
Notnull用来规定表格中某一列的值不能为空。
Primarykey则为表格中的所有记录规定了唯一的标识符。
查询
简单的SQL查询只包括选择列表、FROM子句和WHERE子句。
它们分别说明所查询列、查询的
表或视图、以及搜索条件等。
完整结构:
Select[All/Distinct]<目标表达式>[<目标表达式>]…From<表名>[,<表名>]…[Where<条件表达式>][Groupby<列名1>[Having<条件表达式>]][Orderby<列名2>[Asc/Desc]]
Groupby:
按列名1的值进行分组,属性值相等的为一个组,如果带Having短句,表示只有满足指定条件的才输出。
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。
SELECTnickname,email
FROMtesttable
WHEREname='张三'
(一)选择列表
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变
量和全局变量)等构成。
1、选择所有列
例如,下面语句显示testtable表中所有列的数据:
SELECT*
FROMtesttable
2、选择部分列并指定它们的显示次序
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。
例如:
SELECTnickname,email
FROMtesttable
3、更改列标题
在选择列表中,可重新指定列标题。
定义格式为:
列标题=列名
列名列标题
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列
标题:
SELECT昵称=nickname,电子邮件=email
FROMtesttable
4、删除重复行
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认
为ALL。
使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。
5、限制返回的行数
使用TOPn[PERCENT]选项限制返回的数据行数,TOPn说明返回n行,而TOPnPERCENT时,说明n是
表示一百分数,指定返回的行数等于总行数的百分之几。
例如:
SELECTTOP2*
FROMtesttable
SELECTTOP20PERCENT*
FROMtesttable
(二)FROM子句
FROM子句指定SELECT语句查询及与查询相关的表或视图。
在FROM子句中最多可指定256个表或视图,
它们之间用逗号分隔。
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列
所属的表或视图。
例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应
使用下面语句格式加以限定:
SELECTusername,citytable.cityid
FROMusertable,citytable
WHEREusertable.cityid=citytable.cityid
在FROM子句中可用以下两种格式为表或视图指定别名:
表名as别名
表名别名
(二)FROM子句
FROM子句指定SELECT语句查询及与查询相关的表或视图。
在FROM子句中最多可指定256个表或视图,
它们之间用逗号分隔。
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列
所属的表或视图。
例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应
使用下面语句格式加以限定:
SELECTusername,citytable.cityid
FROMusertable,citytable
WHEREusertable.cityid=citytable.cityid
在FROM子句中可用以下两种格式为表或视图指定别名:
表名as别名
表名别名
例如上面语句可用表的别名格式表示为:
SELECTusername,b.cityid
FROMusertablea,citytableb
WHEREa.cityid=b.cityid
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。
例如:
SELECTa.au_fname+a.au_lname
FROMauthorsa,titleauthorta
(SELECTtitle_id,title
FROMtitles
WHEREytd_sales>10000
)ASt
WHEREa.au_id=ta.au_id
ANDta.title_id=t.title_id
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。
(三)使用WHERE子句设置查询条件
WHERE子句设置查询条件,过滤掉不需要的数据行。
例如下面语句查询年龄大于20的数据:
SELECT*
FROMusertable
WHEREage>20
WHERE子句可包括各种条件运算符:
比较运算符(大小比较):
>、>=、=、<、<=、<>、!
>、!
<
范围运算符(表达式值是否在指定的范围):
BETWEEN…AND…
NOTBETWEEN…AND…
列表运算符(判断表达式是否为列表中的指定项):
IN(项1,项2……)
NOTIN(项1,项2……)
模式匹配符(判断值是否与指定的字符通配格式相符):
LIKE、NOTLIKE
空值判断符(判断表达式是否为空):
ISNULL、NOTISNULL
逻辑运算符(用于多条件的逻辑连接):
NOT、AND、OR
1、范围运算符例:
ageBETWEEN10AND30相当于age>=10ANDage<=30
2、列表运算符例:
countryIN('Germany','China')
3、模式匹配符例:
常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。
可用于char、
varchar、text、ntext、datetime和smalldatetime等类型查询。
可使用以下通配字符:
百分号%:
可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。
下划线_:
匹配单个任意字符,它常用来限制表达式的字符长度。
方括号[]:
指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。
[^]:
其取值也[]相同,但它要求所匹配对象为指定字符以外的任一个字符。
例如:
限制以Publishing结尾,使用LIKE'%Publishing'
限制以A开头:
LIKE'[A]%'
限制以A开头外:
LIKE'[^A]%'
4、空值判断符例WHEREageISNULL
5、逻辑运算符:
优先级为NOT、AND、OR
(四)查询结果排序
使用ORDERBY子句对查询返回的结果按一列或多列排序。
ORDERBY子句的语法格式为:
ORDERBY{column_name[ASC|DESC]}[,…n]
其中ASC表示升序,为默认值,DESC为降序。
ORDERBY不能按ntext、text和image数据类型进行排
序。
例如:
SELECT*
FROMusertable
ORDERBYagedesc,useridASC
另外,可以根据表达式进行排序。
向表格中插入数据
SQL语言使用insert语句向数据库表格中插入或添加新的数据行。
Insert语句的使用格式如下:
insertintotablename
(first_column,...last_column)
values(first_value,...last_value);
例如:
insertintoemployee
(firstname,lastname,age,address,city)
values(‘Li’,‘Ming’,45,‘No.77ChanganRoad’,‘Beijing”);
简单来说,当向数据库表格中添加新记录时,在关键词insertinto后面输入所要添加的表格名称,然后在括号中列出将要添加新值的列的名称。
最后,在关键词values的后面按照前面输入的列的顺序对应的输入所有要添加的记录值。
更新记录
SQL语言使用update语句更新或修改满足规定条件的现有记录。
Update语句的格式为:
updatetablename
setcolumnname=newvalue[,nextcolumn=newvalue2...]
wherecolumnnameOPERATORvalue[and|orcolumnOPERATORvalue];
例如:
updateemployee
setage=age+1
wherefirst_name=‘Mary’andlast_name=‘Williams’;
使用update语句时,关键一点就是要设定好用于进行判断的where条件从句。
删除记录
SQL语言使用delete语句删除数据库表格中的行或记录。
Delete语句的格式为:
deletefromtablename
wherecolumnnameOPERATORvalue[and|orcolumnOPERATORvalue];
例如:
deletefromemployee
wherelastname=May;
简单来说,当需要删除某一行或某个记录时,在deletefrom关键词之后输入表格名称,然后在where从句中设定删除记录的判断条件。
注意,如果用户在使用delete语句时不设定where从句,则表格中的所有记录将全部被删除。
删除数据库表格
在SQL语言中使用droptable命令删除某个表格以及该表格中的所有记录。
Droptable命令的使用格式为:
droptabletablename;
例如:
droptableemployee;
如果用户希望将某个数据库表格完全删除,只需要在droptable命令后输入希望删除的表格名称即可。
Droptable命令的作用与删除表格中的所有记录不同。
删除表格中的全部记录之后,该表格仍然存在,而且表格中列的信息不会改变。
而使用droptable命令则会将整个数据库表格的所有信息全部删除。
三、数据控件
1、ADO数据控件
1.1ADO对象模型
ADO(ActiveXDataObject)数据访问接口是Microsoft处理数据库信息的最新技术。
它是一种ActiveX对象,采用了被称为OLEDB的数据访问模式,是数据访问对象DAO、远程数据对象RDO和开放数据库互连ODBC三种方式的扩展。
ADO对象模型定义了—个可编程的分层对象集合,主要由三个对象成员Connection、Command和Recordset对象,以及几个集合对象Errors、Parameters和Fields等所组成。
图9.13示意了这些对象之间的关系。
表9.6是对这些对象的分工描述。
Connection对象
Error对象
Error集合
Command对象
Parameter对象
Parameter集合
Recordset对象
Field对象
Field集合
图9.13ADO对象模型
表9.6ADO对象描述
对象名
描述
Connection
连接数据来源
Command
从数据源获取所需数据的命令信息
Recordset
所获得的一组记录组成的记录集
Error
在访问数据时,由数据源所返回的错误信息
Parameter
与命令对象有关的参数
Field
包含了记录集中某个字段的信息
要想在程序中使用ADO对象,必须先为当前工程引用ADO的对象库。
引用方式是执行“工程”菜单的“引用”命令,启动引用对话框,在清单中选取“MicrosoftActiveXDataObjects2.0Library”选项。
1.2使用ADO数据控件
在使用ADO数据控件前,必须先通过“工程|部件”菜单命令选择"MicrosoftADODataControl6.0(OLEDB)”选项,将ADO数据控件添加到工具箱。
ADO数据控件与VisualBasic的内部Data控件很相似,它允许使用ADO数据控件的基本属性快速地创建与数据库的连接。
1.ADO数据控件的基本属性
(1)ConnectionString属性
ADO控件没有DatabaseName属性,它使用ConnectionString属性与数据库建立连接。
该属性包含了用于与数据源建立连接的相关信息,ConnectionString属性带有4个参数,如表9.7所示。
(2)RecordSource属性
RecordSource确定具体可访问的数据,这些数据构成记录集对象Recordset。
该属性值可以是数据库中的单个表名,一个存储查询,也可以是使用SQL查询语言的一个查询字符串。
表9.7ConnectionString属性参数
参数
描述
Provide
指定数据源的名称
FileName
指定数据源所对应的文件名
RemoteProvide
在远程数据服务器打开一个客户端时所用的数据源名称
RemoteServer
在远程数据服务器打开一个主机端时所用的数据源名称
(3)ConnectionTimeout属性
用于数据连接的超时设置,若在指定时间内连接不成功显示超时信息。
(4)MaxRecords属性
定义从一个查询中最多能返回的记录数。
2.ADO数据控件的方法和事件
ADO数据控件的方法和事件与Data控件的方法和事件完全一样。
3.设置ADO数据控件的属性
下面通过使用ADO数据控件连接Student.mdb数据库来说明ADO数据控件属性的设置。
步骤1:
在窗体上放置ADO数据控件,控件名采用默认名“Adodcl”。
步骤2:
单击ADO控件属性窗口中的ConnectionString属性右边的“…”按钮,弹出“属性页”对话框。
在该对话框中允许通过三种不同的方式连接数据源:
“使用连接字符串”只需要单击“生成”按钮,通过选项设置自动产生连接字符串。
“使用DataLink文件”表示通过—个连接文件来完成。
“使用ODBC数据资源名称”可以通过下拉式列表框,选择某个创建好的数据源名称(DSN),作为数据来源对远程数据库进行控制。
步骤3:
采用“使用连接字符串”方式连接数据源。
单击“生成”按钮,打开“数据链接属性”对话框。
在“提供者”选项卡内选择一个合适的OLEDB数据源,Student.mdb是Access数据库,选择“MicrosoftJet3.51OLEDBProvider”选项。
然后单击“下—步”按钮或打开“连接”选项卡,在对话框内指定数据库文件,这里为Student.mdb。
为保证连接有效,可单击“连接”选项卡右下方的“测试连接”按钮,如果测试成功则关闭ConnectionString属性页。
步骤4:
单击ADO控件属性窗口中的RecordSource属性右边的“…”按钮,弹出记录源属性页对话框。
在“命令类型”下拉式列表框中选择“2adCmdTable”选项,在“表或存储过程名称”下拉式列表框中选择Student.mdb数据库中的“基本情况”表,关闭记录源属性页。
此时,已完成了ADO数据控件的连接工作。
由于ADO数据控件是一个ActiveX控件,也可以用鼠标右键单击ADO数据控件,在弹出的快捷菜单中选择“ADODC属性”菜单命令,打开ADO数据控件属性页对话框,一次完成步骤1~步骤4的全部设置。
1.3ADO数据控件上新增绑定控件的使用
随着ADO对象模型的引入,VisualBasic6.0除了保留以往的一些绑定控件外,又提供了一些新的成员来连接不同数据类型的数据。
这些新成员主要有DataGrid、DataCombo、DataList、DataReport、MSHFlexGrid、MSChart控件和MonthView等控件。
这些新增绑定控件必须使用ADO数据控件进行绑定。
VisualBasic6.0在绑定控件上不仅对DataSource和DataField属性在连接功能上作了改进,又增加了DataMember与DataFormat属性使数据访问的队列更加完整。
DataMember属性允许处理多个数据集,DataFormat属性用于指定数据内容的显示格式。
例9.6使用ADO数据控件和DataGrid数据网格控件浏览数据库Student.mdb,并使之具有编辑功能。
在窗体上放置ADO数据控件,并按前面介绍的ADO数据控件属性设置过程连接数据库Student.mdb中的基本情况表。
DataGrid控件允许用户同时浏览或修改多个记录的数据。
在使用DataGrid控件前也必须先通过“工程|部件”菜单命令选择“MicrosoftDataGridControl6.0(OLEDB)”选项,将DataGrid控件添加到工具箱,再将DataGrid控件放置到窗体上。
设置DataGrid网格控件的DataSource属性为Adodc1,就可将DataGrid1绑定到数据控件Adodc1上。
显示在DataGrid网格内的记录集,可以通过DataGrid控件的AllowAddNew、AllowDelete和AllowUpdate属性设置控制增,删、改操作。
如果要改变DataGrid网格上显示的字段,可用鼠标右键单击DataGrid控件,在弹出的快捷菜单中选择“检索字段”选项。
VisualBasic提示是否替换现有的网格布局,单击“是”按钮就可将表中的字段装载到DataGrid控件中。
再次用鼠标右键单击DataGrid控件,在弹出的快捷菜单中选择“编辑”选项,进入数据网格字段布局的编辑状态,此时,当鼠标指在字段名上时,鼠标指针变成黑色向下箭头。
用鼠标右键单击需要修改的字段名,在弹出的快捷菜单中选择“删除”选项,就可从DataGrid控件中删除该字段,也可选择“属性”选项修改字段的显示宽度或字段标题。
图9.14所示为具有增、删、改功能的数据网格绑定。
标有号的记录行表示允许增加新记录。
图9.14具有增、删、改功能的数据网格绑定
2、D