VB数据库编程技术实例.docx
《VB数据库编程技术实例.docx》由会员分享,可在线阅读,更多相关《VB数据库编程技术实例.docx(43页珍藏版)》请在冰点文库上搜索。
VB数据库编程技术实例
VB数据库编程技术
一ODBC概述
ODBC就是一套开放数据库系统应用程序接口规范,目前它已成为一种工业标准,它提供了统一得数据库应用编程接口(API),为应用程序提供了一套高层调用接口规范与基于动态连接库得运行支持环境。
使用ODBC开发数据库应用时,应用程序调用得就是标准得ODBC函数与SQL语句,屏蔽了DBMS之间得差异,数据库底层操作由各个数据库得驱动程序完成。
因此应用程序有很好得适应性与可移植性,并且具备了同时访问多种数据库管理系统得能力,从而彻底克服了传统数据库应用程序得缺陷。
CIhNj。
主要任务包括:
建立与数据源得连接;向数据源发送SQL请求;断开与数据源得连接
数据源
数据源就是指任一种可以通过ODBC连接得数据库管理系统,它包括要访问得数据库与数据库得运行平台。
数据源名掩盖了数据库服务器或数据库文件间得差别,通过定义多个数据源,每个数据源指向一个服务器名,就可在应用程序中实现同时访问多个DBMS得目得。
Any6R。
数据源(DataSourceName,简称DSN)就是驱动程序与DBS连接得桥梁,数据源不就是DBS,而就是用于表达一个ODBC驱动程序与DBMS特殊连接得命名。
在连接中,用数据源名来代表用户名、服务器名、所连接得数据库名等,可以将数据源名瞧成就是与一个具体数据库建立得连接。
yu1kj。
数据源分为以下三类:
(1)用户数据源:
用户创建得数据源,称为“用户数据源”。
此时只有创建者才能使用,并且只能在所定义得机器上运行。
任何用户都不能使用其她用户创建得用户数据源。
TqDRr。
(2)系统数据源:
所有用户与在WindowsNT下以服务方式运行得应用程序均可使用系统数据源。
(3)文件数据源:
文件数据源就是ODBC3、0以上版本增加得一种数据源,可用于企业用户,ODBC驱动程序也安装在用户得计算机上。
(与机器无关)1iU9A。
二、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则为表格中得所有记录规定了唯一得标识符。
rNy48。
查询
简单得SQL查询只包括选择列表、FROM子句与WHERE子句。
它们分别说明所查询列、查询得
表或视图、以及搜索条件等。
gE9Sa。
完整结构:
Select[All/Distinct]<目标表达式>[<目标表达式>]…From<表名>[,<表名>]…[Where<条件表达式>][Groupby<列名1>[Having<条件表达式>]][Orderby<列名2>[Asc/Desc]]nHWAl。
Groupby:
按列名1得值进行分组,属性值相等得为一个组,如果带Having短句,表示只有满足指定条件得才输出。
avEo5。
例如,下面得语句查询testtable表中姓名为“张三”得nickname字段与email字段。
SELECTnickname,email
FROMtesttable
WHEREname='张三'8iFIj。
(一)选择列表
选择列表(select_list)指出所查询列,它可以就是一组列名列表、星号、表达式、变量(包括局部变
量与全局变量)等构成。
DjlTg。
1、选择所有列
例如,下面语句显示testtable表中所有列得数据:
SELECT*
FROMtesttableZnjpB。
2、选择部分列并指定它们得显示次序
查询结果集合中数据得排列顺序与选择列表中所指定得列名排列顺序相同。
例如:
SELECTnickname,email
FROMtesttableTFfuE。
3、更改列标题
在选择列表中,可重新指定列标题。
定义格式为:
列标题=列名
列名列标题
如果指定得列标题不就是标准得标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列
标题:
SELECT昵称=nickname,电子邮件=email
FROMtesttableBmWmo。
4、删除重复行
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件得所有行或删除其中重复得数据行,默认
为ALL。
使用DISTINCT选项时,对于所有重复得数据行在SELECT返回得结果集合中只保留一行。
HGnoZ。
5、限制返回得行数
使用TOPn[PERCENT]选项限制返回得数据行数,TOPn说明返回n行,而TOPnPERCENT时,说明n就是
表示一百分数,指定返回得行数等于总行数得百分之几。
例如:
SELECTTOP2*
FROMtesttable
SELECTTOP20PERCENT*
FROMtesttableLhvx0。
(二)FROM子句
FROM子句指定SELECT语句查询及与查询相关得表或视图。
在FROM子句中最多可指定256个表或视图,
它们之间用逗号分隔。
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列
所属得表或视图。
例如在usertable与citytable表中同时存在cityid列,在查询两个表中得cityid时应
使用下面语句格式加以限定:
SELECTusername,citytable、cityid
FROMusertable,citytable
WHEREusertable、cityid=citytable、cityid
在FROM子句中可用以下两种格式为表或视图指定别名:
表名as别名
表名别名TEIbY。
(二)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,然后再从中检索数据。
eEDnf。
(三)使用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
另外,可以根据表达式进行排序。
Bfa4S。
向表格中插入数据
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得后面按照前面输入得列得顺序对应得输入所有要添加得记录值。
8kdVN。
更新记录
SQL语言使用update语句更新或修改满足规定条件得现有记录。
Update语句得格式为:
updatetablename
setcolumnname=newvalue[,nextcolumn=newvalue2、、、]
wherecolumnnameOPERATORvalue[and|orcolumnOPERATORvalue];
例如:
updateemployee
setage=age+1
wherefirst_name=‘Mary’andlast_name=‘Williams’;
使用update语句时,关键一点就就是要设定好用于进行判断得where条件从句。
qPvrb。
删除记录
SQL语言使用delete语句删除数据库表格中得行或记录。
Delete语句得格式为:
deletefromtablename
wherecolumnnameOPERATORvalue[and|orcolumnOPERATORvalue];
例如:
deletefromemployee
wherelastname=May;
简单来说,当需要删除某一行或某个记录时,在deletefrom关键词之后输入表格名称,然后在where从句中设定删除记录得判断条件。
注意,如果用户在使用delete语句时不设定where从句,则表格中得所有记录将全部被删除。
4R9Ox。
删除数据库表格
在SQL语言中使用droptable命令删除某个表格以及该表格中得所有记录。
Droptable命令得使用格式为:
droptabletablename;
例如:
droptableemployee;
如果用户希望将某个数据库表格完全删除,只需要在droptable命令后输入希望删除得表格名称即可。
Droptable命令得作用与删除表格中得所有记录不同。
删除表格中得全部记录之后,该表格仍然存在,而且表格中列得信息不会改变。
而使用droptable命令则会将整个数据库表格得所有信息全部删除。
Mm3gj。
三、数据控件
1、ADO数据控件
1、1ADO对象模型
ADO(ActiveXDataObject)数据访问接口就是Microsoft处理数据库信息得最新技术。
它就是一种ActiveX对象,采用了被称为OLEDB得数据访问模式,就是数据访问对象DAO、远程数据对象RDO与开放数据库互连ODBC三种方式得扩展。
ADO对象模型定义了—个可编程得分层对象集合,主要由三个对象成员Connection、mand与Recordset对象,以及几个集合对象Errors、Parameters与Fields等所组成。
图9、13示意了这些对象之间得关系。
表9、6就是对这些对象得分工描述。
8O8GN。
图9、13ADO对象模型
表9、6ADO对象描述
对象名
描述
Connection
连接数据来源
mand
从数据源获取所需数据得命令信息
Recordset
所获得得一组记录组成得记录集
Error
在访问数据时,由数据源所返回得错误信息
Parameter
与命令对象有关得参数
Field
包含了记录集中某个字段得信息
要想在程序中使用ADO对象,必须先为当前工程引用ADO得对象库。
引用方式就是执行“工程”菜单得“引用”命令,启动引用对话框,在清单中选取“MicrosoftActiveXDataObjects2、0Library”选项。
hseqy。
1、2使用ADO数据控件
在使用ADO数据控件前,必须先通过“工程|部件”菜单命令选择"MicrosoftADODataControl6、0(OLEDB)”选项,将ADO数据控件添加到工具箱。
ADO数据控件与VisualBasic得内部Data控件很相似,它允许使用ADO数据控件得基本属性快速地创建与数据库得连接。
Uim1z。
1.ADO数据控件得基本属性
(1)ConnectionString属性
ADO控件没有DatabaseName属性,它使用ConnectionString属性与数据库建立连接。
该属性包含了用于与数据源建立连接得相关信息,ConnectionString属性带有4个参数,如表9、7所示。
g6Chf。
(2)RecordSource属性
RecordSource确定具体可访问得数据,这些数据构成记录集对象Recordset。
该属性值可以就是数据库中得单个表名,一个存储查询,也可以就是使用SQL查询语言得一个查询字符串。
Uns95。
表9、7ConnectionString属性参数
参数
描述
Provide
指定数据源得名称
指定数据源所对应得文件名
RemoteProvide
在远程数据服务器打开一个客户端时所用得数据源名称
RemoteServer
在远程数据服务器打开一个主机端时所用得数据源名称
(3)ConnectionTimeout属性
用于数据连接得超时设置,若在指定时间内连接不成功显示超时信息。
(4)MaxRecords属性
定义从一个查询中最多能返回得记录数。
2、ADO数据控件得方法与事件
ADO数据控件得方法与事件与Data控件得方法与事件完全一样。
3.设置ADO数据控件得属性
下面通过使用ADO数据控件连接Student、mdb数据库来说明ADO数据控件属性得设置。
步骤1:
在窗体上放置ADO数据控件,控件名采用默认名“Adodcl”。
步骤2:
单击ADO控件属性窗口中得ConnectionString属性右边得“…”按钮,弹出“属性页”对话框。
在该对话框中允许通过三种不同得方式连接数据源:
MeYH2。
“使用连接字符串”只需要单击“生成”按钮,通过选项设置自动产生连接字符串。
“使用DataLink文件”表示通过—个连接文件来完成。
“使用ODBC数据资源名称”可以通过下拉式列表框,选择某个创建好得数据源名称(DSN),作为数据来源对远程数据库进行控制。
ZEqhD。
步骤3:
采用“使用连接字符串”方式连接数据源。
单击“生成”按钮,打开“数据链接属性”对话框。
在“提供者”选项卡内选择一个合适得OLEDB数据源,Student、mdb就是Access数据库,选择“MicrosoftJet3、51OLEDBProvider”选项。
然后单击“下—步”按钮或打开“连接”选项卡,在对话框内指定数据库文件,这里为Student、mdb。
为保证连接有效,可单击“连接”选项卡右下方得“测试连接”按钮,如果测试成功则关闭ConnectionString属性页。
lyCSF。
步骤4:
单击ADO控件属性窗口中得RecordSource属性右边得“…”按钮,弹出记录源属性页对话框。
cP4o9。
在“命令类型”下拉式列表框中选择“2-adCmdTable”选项,在“表或存储过程名称”下拉式列表框中选择Student、mdb数据库中得“基本情况”表,关闭记录源属性页。
此时,已完成了ADO数据控件得连接工作。
J1S1r。
由于ADO数据控件就是一个ActiveX控件,也可以用鼠标右键单击ADO数据控件,在弹出得快捷菜单中选择“ADODC属性”菜单命令,打开ADO数据控件属性页对话框,一次完成步骤1~步骤4得全部设置。
cmJkh。
1、3ADO数据控件上新增绑定控件得使用
随着ADO对象模型得引入,VisualBasic6、0除了保留以往得一些绑定控件外,又提供了一些新得成员来连接不同数据类型得数据。
这些新成员主要有DataGrid、Databo、DataList、DataReport、MSHFlexGrid、MSChart控件与MonthView等控件。
这些新增绑定控件必须使用ADO数据控件进行绑定。
Q8pjQ。
VisualBasic6、0在绑定控件上不仅对DataSource与DataField属性在连接功能上作了改进,又增加了DataMember与DataFormat属性使数据访问得队列更加完整。
DataMember属性允许处理多个数据集,DataFormat属性用于指定数据内容得显示格式。
sP8jt。
例9、6使用ADO数据控件与DataGrid数据网格控件浏览数据库Student、mdb,并使之具有编辑功能。
KuKva。
在窗体上放置ADO数据控件,并按前面介绍得ADO数据控件属性设置过程连接数据库Student、mdb中得基本情况表。
reIJH。
DataGrid控件允许用户同时浏览或修改多个记录得数据。
在使用DataGrid控件前也必须先通过“工程|部件”菜单命令选择“MicrosoftDataGridControl6、0(OLEDB)”选项,将DataGrid控件添加到工具箱,再将DataGrid控件放置到窗体上。
设置DataGrid网格控件得DataSource属性为Adodc1,就可将DataGrid1绑定到数据控件Adodc1上。
2mL3u。
显示在DataGrid网格内得记录集,可以通过DataGrid控件得AllowAddNew、AllowDelete与AllowUpdate属性设置控制增,删、改操作。
5uU5D。
如果要改变DataGrid网格上显示得字段,可用鼠标右键单击DataGrid控件,在弹出得快捷菜单中选择“检索字段”选项。
VisualBasic提示就是否替换现有得网格布局,单击“就是”按钮就可将表中得字段装载到DataGrid控件中。
再次用鼠标右键单击DataGrid控件,在弹出得快捷菜单中选择“编辑”选项,进入数据网格字段布局得编辑状态,此时,当鼠标指在字段名上时,鼠标指针变成黑色向下箭头。
用鼠标右键单击需要修改得字段名,在弹出得快捷菜单中选择“删除”选项,就可从DataGrid控件中删除该字段,也可选择“属性”选项修改字段得显示宽度或字段标题。
6KsYG。
图9、14所示为具有增、删、改功能得数据网格绑定。