空间管理 您的位置: DOIT博客 » 梦飞想 » 日志

用VB访问SQL Server数据库技术详解

上一篇 / 下一篇  2006-09-01 10:33:03

查看( 1270 ) / 评论( 3 )
本文讨论了Visual Basic应用程序访问SQL Server数据库的几种常用的方法,分别说明了每种方法的内部机理并给出了每种方法的一个简单的实例,最后比较了每种方法性能和优缺点。 DOIT博客T uW'Vs'y${
DOIT博客 umx|Z
一、引言   DOIT博客'_ Bz&M*?1]-D&q

cz"@$m-v(qi7S]0
E1d}/n/z~ X\#K0 SQL Server是微软推出的中小型网络数据库系统,是目前最常用的数据库系统之一。随着SQL Server网络数据库应用程序日益增多,这种Web数据库应用系统的正常运行一般依赖于已存在的用户数据库。创建维护数据库的工作可用SQL Server提供的SQL Enterprise Manager工具来进行,如能提供一种定制的数据库管理工具,通过管理应用程序来管理数据库及其设备,对用户来说无疑是最理想的。
*j Z"G#E]3y!j0
3X5C^gAa e2X%?0
n5D"S5C3f|2}0 Visual Basic作为一种面向对象的可视化编程工具,具有简单易学,灵活方便和易于扩充的特点。而且Microsoft为其提供了与SQL Server通信的API函数集及工具集,因此它越来越多地用作大型公司数据和客户机—服务器应用程序的前端,与后端的Microsoft SQL Server相结合,VB能够提供一个高性能的客户机—服务器方案。  
q`1G/pAh9\`0 DOIT博客,}F%^b-},k d9xb7S8H
DOIT博客&O6rLQsn
二、VB访问SQL Server数据的常用方法 DOIT博客~L RP!w,_d1V
DOIT博客/{q2K7^H4D M;d
DOIT博客-r[(dGG?;qK/R3i
使用Visual Basic作为前端开发语言,与SQL Server接口有几种常用的方法,即:
jp [2V,` V6jL0
OM1j { q0
]L!cH`$gn0 ①数据访问对象/Jet
"xY2n'G H%LyP0 DOIT博客/{N4r&m6H0@C zM

A!X-c,nIKu%h5P0 ②为ODBC API编程 DOIT博客Kn~0RRG h

"Q_@+w t2xp E0 DOIT博客r1d4r3cg(c]EQ
③使用SQL Server的Visual Basic库(VBSQL)为DB库的API编程
j,}6I{A$I0 DOIT博客;g.snQ Oq@

;_xE;df,\!E^0 ④RDO 远程数据对象(RemoteData Objects) DOIT博客 z+Zu h#j$LYY

/RS uY'IL\+W,@oU0
` GUaD'`aLb0 ⑤ADO 数据对象(Active Data Objects) DOIT博客 b!}ecS:H/n7wf

,b$Jq w\*TIL K0
"e T ^ b6L2V#Ka}Y0 1、数据访问对象/Jet
}%EOBV/w"tt0
aQI6u rB"j)T~j0
"L eZ"Q7_I;A*Ug K F0 VB支持Data Access Objects(DAOs)的子集。DAO的方法虽然不是性能最好的管理客户机—服务器之间的对话方式,但它的确有许多优点。DAO/Jet是为了实现从VB访问Access数据库而开发的程序接口对象。使用DAOs访问SQL Server的过程如下:应用程序准备好语句并送至Jet,Jet引擎(MASJT200.DLL)优化查询,载入驱动程序管理器并与之通讯,驱动程序管理器(ODBC.DLL)通过调用驱动器(SQLSRVR.DLL)的函数,实现连接到数据源,翻译并向SQL Server提交SQL语句且返回结果。下面是一个用DAOs访问SQL Server的VB实例。DOIT博客4m4v x4]uB
DOIT博客A4m~`I{~&v
注释:Form Declarations DOIT博客 b0f7o7U}:qwq
DOIT博客qF fY9Is/Vc
Dim mydb As Database DOIT博客 qItK3I*yt
Dim mydynaset As Dynaset オ DOIT博客3v!nw(k-Y(JG
Private Sub Form_Load()
#kO`z*dl Z0   Set mydb = OpenDatabase("", False, False, "ODBC; DSN=Myserver; WSID=LCL; DATABASE = sales")
uv f.i:[6S \;b4UG0   Set mydynaset = mydb CreateDynaset("Select*from Customers") オ
D1S r5?3@ OBCM0 End Sub
上述例子是以非独占、非只读方式打开sales数据库,并检索Customers表中的所有字段。OpenDatabase函数的最后一个参数是ODBC连接字符串参数,它指明了Microsoft Access连接到SQL Server所需要知道的一些内容。其中“DSN”为数据源名,“WSID”为工作站名,“DATABASE”为所要访问的数据库名。DOIT博客(k'O,GNi,v/d

w*}XcIW0 2、利用ODBC API编程 DOIT博客!EEcPZI!BA;H
DOIT博客:d \2R+h*~ K.kqS
DOIT博客Y k] p,WI6K%b
ODBC(Open Database Connectivity)的思想是访问异种数据库的一种可移植的方式。与数据资源对话的公用函数组装在一个称为驱动程序管理器(ODBC.DLL)的动态连接中。应用程序调用驱动程序管理器中的函数,而驱动程序管理器反过来通过驱动器(SQLSRVR.DLL)把它们送到服务器中。 DOIT博客'x${u8j^w
DOIT博客.S6X5HJ.MC3^9^5i
DOIT博客 R"z[ ^ ~#i
下面的代码使用上面一些函数先登录到一个服务器数据库,并为随后的工作设置了语句句柄。
6^4n _.Q'WN2E*c gRB}I0
,zw0C;B h/}9^7c~0
Global giHEnv As Long DOIT博客Lib1[5c
Global giHDB As Long DOIT博客'l O:N1B iT
Global giHStmt As Long
$}}Y^Vz0 DOIT博客C"a.o!S'g8XvR
Dim myResult As integer DOIT博客9S @aJVO
Dim myConnection As Srting
D+H:`%p|6YIW0 Dim myBuff As String*256
|(ej1fC9T0 Dim myBufflen As Integer
:_Pr5w`*@%y?7Y0
/k8C%l"z+Y3F+X.wK0 If SQLAllocEnv(giHEnv)<>SQL_SUCCESS Then
O`e:GFk5t'O)Q?m6f0   MsgBox"Allocation couldn注释:t happen!"
-E/S(F4B"K ]S0 End If DOIT博客3[4A,b-PN F i&eu_
If SQLAllocConnect(giHEnv,giHDB)<>SQL_SUCCESS Then DOIT博客*w:K!t'p1Fy&e
  MsgBox "SQL Server couldn注释:t connect!" DOIT博客uRDN5|%YI
End If DOIT博客rlql6J L
myConnection="DSN=myServer;UID=LCL;PWD=;APP=ODBCTest;WSID=LCL;DATABASE=sales"
c9y{4i t*RD!a8s.]7A G(q0    myResult=SQLDriverConnect(giHDB,Test,form1.hWnd,myConnection.len(myConnection),DOIT博客l6M"a-j'MCnG
   myBuff,256,myBufflen,SQL_DRIVER_COMPLETE_REQU IE D)
5b+H?}v{y1v Rw0    myResult=SQLAllocStmt(giHDS,giHStmt) DOIT博客-xg gV4l \'e
   myResult=SQLFreeStmt(giHStmt,SQL_COLSE)
@Iu;WS0    rsSQL="Select * from Customers Where City = "Hunan"" DOIT博客1@8YqS5[3A(La4o
   myResult = SQLExecDirect(giHStmt,rsSQL,Len(rsSQL))
3、使用VBSQL对DB库API编程
EoM%M7@X-ZuQ0
!FK6]z6V@2C0 DOIT博客L p.Q r5h
DB库是SQL Server的本地API,SQL Server的Visual Basic库(VBSQL)为Visual Basic程序员提供API。从一定意义上说,VBSQL是连接Visual Basic程序到SQL Server的性能最好最直接的方式。VBSQL包含以下三个文件:
4D|?EKB0 DOIT博客(g*FF_A1d}:W&h1W
VBSQL.VBX: 包含库函数,具有访问重要的消息和处理错误的能力
R9OD;G8b0 DOIT博客F3oAE+h4IV ?nzP
VBSQL.BI:包括所有的常量和变量说明 DOIT博客'o _5Q1L7Ilc

0Q UzF"[-[ c.x'}3j&}A0 VBSQL.HLP:Windows帮助文件,使用VBSQL的指南
&RIc]\ T:\dxJ i0 DOIT博客c'DBu9b
使用VBSQL时,必须将VBSQL.BI加入到Visual Basic工程文件中,并确保VB程序运行时有VBSQL.VBX文件。   DOIT博客!t\0Z/`6d)X

}%\i} Fm0 一般的DB库API编程的过程是这样的:先通过调用SqlInit对DB库进行初始化,再调用SqlConnection打开一个连接,然后就可做一些工作。下面的代码是一个初始化DB库并登录到服务器的通用例程。DOIT博客 dv8tJ d bF

~ G-_X+ob0
  Private Sub InitializeApplication() DOIT博客'L s?M(?)I.`h
  DBLIB_VERSION=SqlInit()
YX7rs?G e:pKpG0   If DBLIB_VERSION=""Then DOIT博客qh,R#rhn(J
   MsgBox"Could not initialize DBLIB!Exit application.", MB_ICONEXCLAMATION DOIT博客:t*cie!G7g F-y
  End If DOIT博客.MQ B^k4gC
  End Sub  
K3SE/Z0R-s9GKG3Ls0   Private Function LoginToServer() As integer
$m$qr [f#a[0   loginToServer=SUCCEED
m/A;X,`(ntJp0   Status%=SqlSetloginTime%(loginTimeOut)
Tjq.Se"i%i;O?bZ0   If giSqlConn<>0 Then
P'V)g"Tq(v(Z0   SqlClose(giSqlConn) 注释:关闭已打开的连接
5I b ?#y {5l0   giSqlConn=SqlOpenConnection(gsServerName, gsLoginID, gsPassword, ProgramName, ProgramName)
k~;jZ.B&\M0   If giSqlConn<>0 Then DOIT博客k DG9?]
  liresuit=SqlUse(giSqlConn,"Sales")
@e6}*`Ge?0   Else
\ ckt/i9j1N*P0   LogintoServer=FAIL
2B?^1^!f'Of4E0IXM0   End If DOIT博客Kw%PU%Z(Jk
  End Function 
4、RDO 远程数据对象(RemoteData Objects)
#`U9W"q/VaX.I1C0 DOIT博客-A*b.V0^e8s

6] ~,\&kJwZGj0 要讨论RDO,就必然要谈到DAO。RDO是从DAO派生出来的,但两者很大的不同在于其数据库模式。DAO是针对[记录(Records)]和[字段( Fields)],而RDO是作为[行(Rows)]和[列(Columns)]来处理。也就是说DAO 是ISAM模式,RDO是关系模式。此外DAO是访问Access的Jet引擎(Jet是ISAM)的接口,而RDO则是访问ODBC的接口。 DOIT博客yz-M `,^d1}3u-D
DOIT博客1v\#~ i$w;X my

j}#w3[#t:h Za0 可见,RDO是综合了DAO/Jet、VBSQL/DBLib以及ODBC的优点的对象(Object)。需要强调的是,RDO是包裹着ODBC API的一层薄薄的外壳, 被设计成在后台(服务器端)有数据库存在的前提下运行,同时也是针对SQL Server和Oracle而特别设计的。
X7xC*Hig0 DOIT博客D"P)QMHKP*vW

@]I3e*Y.D1z0 RDO的优势在于它完全被集成在VB之中。此外,直接访问SQL Server存储过程、完全支持T-SQL、T-SQL调试集成在开发环境中、Visual Database Tools的集成化等,也是RDO的长处。
|o5X\L\ iI0 DOIT博客#l0u1d V6uP!@
DOIT博客2b[K/@7v4rd]AK{
在RDO的对象和集合中,有很多对数据库的状态和设定进行操作的属性(Property),以及对数据库进行操作的方法(Method)。利用这些,从RDO2.0起就可以开发事件驱动的数据库应用程序。
*t~}n:uF$A C i0
iI;_6\F'f0
9r5Uz O!g"|R)x.Q0 RDO对象与VB中其他对象的概念相同。与VB用的ActiveX控件(以往称为Custom Control或OCX、VBX)相似的是,RDO也带有属性和方法;但同Spread、InputMan等普遍应用的ActiveX控件不同的是,RDO没有自己的用户界面,因而可以和VB标准的Timer控件归为同一类。当然也可以将RDO看作调用ODBC API函数,进而对后台数据库操作加以控制的对象。在RDO的属性和方法中,包含了对单个的ODBC API函数以及一连串API函数的调用。 DOIT博客9w6f8s_o#liT
DOIT博客%O$Z"e.q{?n

8Y(WZ1m^G0 ①rdoEngine对象
*U1g {x5|~k0
8p\7x*U?{O0 DOIT博客l7HX`g6|+cx
最初调用RDO对象以及RDC(远程数据控件)时,自动生成rdoEngine对象的附带事件(incident)。rdoEngine用于对RDO全局属性的参数、选项进行设置,是在RDO的阶层结构内处于最上层的对象,包含了所有的其他对象。
T8_XHY^+E{ZO0 DOIT博客+g-`M3do8^c4h
DOIT博客N7X.h y%Fk,m
rdoEngine对象与DAO/Jet不同,虽然被多个应用程序共享,但体现rdoEngine对象的设定值的属性却并不共用,而是在各自的应用程序的程序界面中对其分别加以设定。这些设定值对其他使用RDO以及RDC的应用程序没有任何影响。rdoEngine不是集合的要素,而是重新定义的对象,rdoEngine对象不能被追加作成对象属性的初值。 DOIT博客 @2Qy!d5B6tqbbd
DOIT博客O2G5DM9F)O%[[a Q
DOIT博客(h"U8}(H'uV,P Z4v`?6o
②rdoEnvironment对象
g|Ci\ H0
a5w+Y8^qr8Y0 DOIT博客snNGQ/G9Gc
RDO对象在自动创建rdoEngine对象时,将rdoEnviroment对象的初始值生成并保存为rdoEnviroments(0)。一般情况下,应用程序中不必追加rdoEnvironment对象,大多只需对已有的rdoEnviroments(0)进行操作就可以了。只有在支持一个以上事务(Transaction),需要将用户名和口令信息分别处理的情况下,利用rdoCreateEnvironment方法将特定的用户名和口令值做成新的rdoEnvironment对象。在这个方法中可以指定固有名、用户名和口令,如果所指定的值与rdoEnvironments集合的已经存在的成员名称相同,会产生错误。新建的rdoEnvironment对象自动追加在rdoEnvironments集合的最后。调rdoCreateEnvironment方法时,其name参数可以是长度为0的文字列,这时新的rdoEnvironment对象将不会被追加在rdoEnvironments集合之中。 DOIT博客^*r1O+L[5l+p:m-u
DOIT博客_-?s+}oW

F2bp/{q|O[0 ③rdoConnection对象 DOIT博客$z&`Wcf!f
DOIT博客{hxm-c;^:~k%U

_nU0|+j2?:j6LO0 rdoConnection对象用于同SQL Server的连接管理。
6GD6Q?W d&Fs)m/u0 DOIT博客"Z,n:[ U{9^8a {

+C3q&CJ Q-F TF0 下面是与SQL Server连接的例子。 DOIT博客"F |.u(l(k y [

)Uu!^n&h(^GrB0 DOIT博客"Zi|N$F
用OpenConnection方法的一个实例。
-LD7lKM!lB_H w:v(`0
Tc0v"zJZR0
[ W$A*J9p;v3A*C?.e:O0 设定的DSN为MyDSN:  DOIT博客-G+Y0E.|-P0H7t

-K5A*n"t9X+P0
Dim Cn As rdoConnection DOIT博客'b8A6h y^7r
Dim En As rdoEnvironment
@c ` V U&J-WS0 Dim Conn As String
z0c3T*BxN6C0 Conn = "DSN = MyDSN; UID = Jacob;" & "PWD = 123456; DATA BASE = MyDb;" DOIT博客(r(inU3Vz}Q'V)Z,w4r
Set Cn= En.OpenConnection("", rdDriverPrompt, False, Co nn) DOIT博客.VGN&J ki`/N
Set Cn= En.OpenConnection(Prompt:= rdDriverPrompt, Rea dOnly:= False,Connect:= Cnn)
用EstablishConnection方法的一个实例。 DOIT博客/B[ q@}c

M q9M*yt1B+g*S[0 这里以独立的rdoConnection对象为例说明与SQL Server的连接。
CG{4`D(Ti9~0DOIT博客#qs@ [O2G_L
Public WithEvents Eng As rdoEngine
:[9G6f?`%bn"i0 Public WithEvents Cn As rdoConnection
3R7~Mu/BR#O Mq0
H(IN;{j-DN El0 Private Sub Form_Load() DOIT博客0n6NJ2J?I{
 Set Eng = New rdoEngine
2X_1p#~$h3X0  Set Cn = New rdoConnection DOIT博客 N#AC"Nxl_8hh
 With Cn
,HE,D(G)L^0   .Connect = "UID = ; PWD = ;" & "DATABASE = pubs; DSN = biblio"
4QIA yk6O!EK0   .LoginTimeout = 5
Z o*A-z-x4]nkR0   .EstablishConnection rdoDriverNoPromt, True, rdAsyncEna ble DOIT博客)Vv&~n BPg
 End With DOIT博客+X/Y2F`6n)` y,\,w
End Sub
在这个例子中,Form_Load函数对rdoEngine和rdoConnection对象进行初始化。这里有一点需要注意,rdoConnection对象是处于独立的状态之下,即使是处于未连接状态也可以设置属性的值。接下来是rdoConnect对象的事件处理程序。从RDO 2.0起可以实现异步方式(rdAsyn cEnable),EstablishConnection就设定为该值。在异步状态下,不必等待与数据库的连接,程序可以迅速从Form_Load 函数中退出。 然后是BeforeConnect事件,该处理在与数据库的连接开始以前被激发,此时不能进行有关终止连接的操作:
m E^$T} oe4b0DOIT博客Z]xM.LQ]}O/a
Private Sub Cn_BeforeConnect(ConnetString As String, Pro mpt As Variant)
4TVM"j4a }y0Wf Ig0  MsgBox "正在连接" & ConnectString, vbOKOnly, "连接前" DOIT博客)? U _F"q:@#G!p
End Sub
连接完成之后的事件处理:
QD hn qSry0
-S-j*~3Nb4C| @0
Private Sub Cn_Connect(ByVal ErrorOccurred As Boolean)
7j?(x8],h8hJ1\+a0  Dim M As String DOIT博客%i2mH.?&l,C]?
 If ErrorOccurred Then
#UN/Fa"~ g)f O0   For Each er In rdoErrors DOIT博客T;yH5S:f x
   M = M & er & vbCrLf & M DOIT博客`N7r2|&yph qft9B
  Next
B(B"\`*w_0   MsgBox "连接失败" & vbCrLf & M DOIT博客']1RO%?5x \co
 Else DOIT博客i V6Lh5| l,V&d&i
  MsgBox "连接成功" DOIT博客8u$Tp.p oF
  注释:这是确认连接状态的测试代码 DOIT博客br&QXI TM'iV
 Cn.Excute "use pubs"
zF7Wt/Wt0 End Sub 
RDO连接处理结束后,在该事件中确认连接成功与否。连接成功的情况下ErrorOccurred返回False,失败时为True,由此可以对rdoErrors集合进行检测:
/M NO t/ISV!r%l ^0DOIT博客rr*x0qO/~
Private Sub Eng_InfoMessage() DOIT博客^\Jq7t xR1B
 For Each er In rdoErrors
g0Xi V/q3P6]:\x([0   Debug.Print er
s%g;o[I_$A6R0  Next
S^sL(xW s IT0  RdoErrors.Clear DOIT博客O*n1F2D|Oz
End Sub
不能与SQL Server连接的原因多种多样,有可能是由于对数据库的访问权限、网络连接问题、数据库表的信息错误、SQL Server同时连接的许可数、资源不足等等,具体情况需要与网络管理员商量。 断开连接的操作非常简单,但又很重要,因为RDO不提供自动断开的功能。   DOIT博客!_&Xp @2Eu%_
DOIT博客J&{0E%_-K7S3r0?N

l2F oK2qU0 Cn.Close DOIT博客n A+W4`b8L'pW

3x{M$~h_^-|t6q7uI0 Set Cn = Nothing 注释:释放对象所占的内存资源
4Px.r8jG0
#^:ot&j[-p&Hm0 En.Close DOIT博客C4v }*E,j8K.w
DOIT博客$pAih ['aa-x+_Y8E']w
Set En = Nothing 注释:释放对象所占的内存资源   DOIT博客!l C0sq|$d
DOIT博客!OGKMl9O'Y ?
VB是对象语言,Form、ActiveX控件也都是对象。使用对象后必须养成将对象设为Nothing把它从内存中释放的编程习惯。这样可以预防很多不可预测错误,往往程序中发生原因不明的错误时,其原因就在于此。

TAG:

梦飞想 angle 发布于2006-09-01 10:34:52
5、ADO 数据对象(Active Data Objects)
T4C)Y
ZXuDOIT博客

6n#zT)n.D2P{B企业, 信息化, 资讯, 宽频, 互动, 解决方案, 成功案例, 存储, 服务器, 网络, 安全, 无线, 开放系统, 商业资源, ERP, CRM, EAI, 软件, IT基础设施, news, vision, solution, case study, storage, server, networking, security, wireless, business intelligenceADO是基于全新的OLE DB技术,OLE DB可对电子邮件、文本文件、复合文件、数据表等各种各样的数据通过统一的接口进行存取。随着ActiveX控件的升级(Windows 98的ActiveX 5.0),RDO将被以ActiveX技术为基础的ADO接口所替代。下面将介绍基于ActiveX技术的ADO访问SQL Server 6.5数据库的技术和方法。基于浏览器的ADO接口常用函数如下: 企业, 信息化, 资讯, 宽频, 互动, 解决方案, 成功案例, 存储, 服务器, 网络, 安全, 无线, 开放系统, 商业资源, ERP, CRM, EAI, 软件, IT基础设施, news, vision, solution, case study, storage, server, networking, security, wireless, business intelligenceP3i.Vd^~;sA-N
space.doit.com.cn*R#I+W(l,G2b(L(i+K,V2y2Y
(1)取当前的工作数据库 e$F }JG
企业, 信息化, 资讯, 宽频, 互动, 解决方案, 成功案例, 存储, 服务器, 网络, 安全, 无线, 开放系统, 商业资源, ERP, CRM, EAI, 软件, IT基础设施, news, vision, solution, case study, storage, server, networking, security, wireless, business intelligencegt Ke-W/NY/J
由于管理任务一般都必须在Master库中完成,因此在执行管理任务之前,最好保存当前工作库,以便完成任务之后再切换回原来的任务。 

CODE:

Public Function SQLGetCurrentDatabaseName(Cn As ADODB.Connection) As String
 Dim sSQL As String
 Dim RS As New ADODB.Recordset
 On Error GoTo errSQLGetCurrentDatabaseName
 sSQL="select CurrentDB=DB_NAME ( )"
 RS.Open sSQL, Cn
 SQLGetCurrentDatabaseName=Trim $ (RS! CurrentDB)
 RS.Close
 Exit Function
 errSQLGetCurrentDatabaseName:
 SQLGetCurrentDatabaseName=" "
End Function 
(2)取SQL Server安装目录下的DATA子目录路径
)kXy(Q8W2wq]DOIT博客-C-B.zT1Z


AE#W:A9p7G%u企业, 信息化, 资讯, 宽频, 互动, 解决方案, 成功案例, 存储, 服务器, 网络, 安全, 无线, 开放系统, 商业资源, ERP, CRM, EAI, 软件, IT基础设施, news, vision, solution, case study, storage, server, networking, security, wireless, business intelligence
取SQL Server的设备文件缺省目录,返回如D:MSSQL DATA。

CODE:

Public Function SQLGetDataPath(Cn As ADODB.Connection) As String
 Dim sSQL As String
 Dim RS As New ADODB.Recordset
 Dim sFullPath As String
 On Error GoTo errSQLGetDataPath
 sSQL="select phyname from master..sysdevices where name=注释:master注释: "
 RS.Open sSQL, Cn
 sFullPath = RS! phyname
 RS.Close
 SQLGetDataPath=Left $ (sFullPath, Len(sFullPath) -10) 注释:MASTER.DAT的大小
  Exit Function
 errSQLGetDataPath:
 SQLGetDataPath=" "
End Function
  
&Jh_5}-}3l企业, 信息化, 资讯, 宽频, 互动, 解决方案, 成功案例, 存储, 服务器, 网络, 安全, 无线, 开放系统, 商业资源, ERP, CRM, EAI, 软件, IT基础设施, news, vision, solution, case study, storage, server, networking, security, wireless, business intelligence ^I{9J+\Y$e&b
c

(3)创建一个新数据库  

CODE:

Public Function SQLCreateDatabase65 (Cn As ADODB.Connection,sDBName
As String, sDataDeviceName As String, nDataSize As Integer, Optional sLogDeviceName,
Optional nLogSize) As Boolean

 Dim sSQL As String
 On Error GoTo errSQLCreateDatabase65
 Dim sDB As String
 sDB =SQLGetCurrentDatabaseName(Cn)
 sSQL = "USE master"
 Cn.Execute sSQL
 sSQL ="CREATE DATABASE" & sDBName
 sSQL = sSQL &" ON " & sDataDeviceName & "=" & nDataSize
 If Not IsMissing(sLogDeviceName) And Not IsMissing(nLogSize) Then
  sSQL = sSQL & "LOG ON" & sLogDeviceName & "="& nLogSize
 End If
 Cn.Execute sSQL
 sSQL = "USE" & sDB
 Cn.Execute sSQL
 SQLCreateDatabase65 = True
 Exit Function
 errSQLCreateDatabase65:
 On Error Resume Next
 sSQL = "USE " & sDB
 Cn.Execute sSQL
 SQLCreateDatabase65 = False
End Function
(4)判断一个数据库是否存在

CODE:

Public Function SQLExistDatabase(Cn As ADODB.Connection, sDBName As String) As Boolean
 Dim sSQL As String
 Dim RS As New ADODB.Recordset
 Dim bTmp As Boolean
 on Error GoTo errSQLExistDatabase
 sSQL = "select CntDB = count ( * ) "
 sSQL = sSQL & "From master.dbo.sysdatabases"
 sSQL = sSQL & "Where name = 注释: "& sDBName & " 注释: "
 RS.Open sSQL, Cn
 If RS! CntDB = 0 Then bTmp = False Else bTmp = True
  RS.Close
  SQLExistDatabase = bTmp
  Exit Function
  errSQLExistDatabase:
  SQLExistDatabase = False
  Exit Function
 End Function
(5)删除一个数据库  

CODE:

Public Function SQLDropDatabase (Cn As ADODB.Connection, sDBName As String) As Boolean
 Dim sSQL As String
 On Error GoTo errSQLDropDatabase
 If Not SQLExistDatabase(Cn, sDBName) Then
  SQLDropDatabase = True
   Exit Function
 End If
 Dim sDB As String
 sDB = SQLGetCurrentDatabaseName(Cn)
 sSQL = "Use master"
 Cn.Execute sSQL
 sSQL = "DROP DATABASE " & sDBName
 Cn.Execute sSQL
 sSQL = "USE " & sDB
 Cn.Execute sSQL
 SQLDropDatabase = True
 Exit Function
errSQLDropDatabase:
 On Error Resume Next
 sSQL = "USE " & sDB
 Cn.Execute sSQL
 SQLDropDatabase = False
End Function 
三、性能比较及应用说明
*hBH JV%zDOIT博客DOIT博客XoYi#R{G?|

6P$l z'g        K'ko4u用VB开发基于SQL Server的数据库系统,以上几种访问SQL Server的方法各有各的特点。DAOs方法是基于对象的,因而便于使用,但是它是从Visual Basic到SQL Server最慢的连接方式。ODBC API和VBSQL方法从本质上讲是基于程序的。ODBC API方法通用性好,允许最强的互操作性,编程简单,但速度慢于VBSQL方法。VBSQL方法通过VBSQL控件,提供了重要的SQL Server前端应用程序所需的灵活性、强大功能和良好性能。它具有真正的事件驱动及错误处理能力,完全支持异步处理、游标和计算列等。这些都是VBSQL方法超出其它方法的优势,但其编程稍复杂。RDO是位于ODBC API之上的一个对象模型层,它依赖ODBC API、ODBC驱动程序以及后端数据库引擎来实现,用RDO所需的程序短小(约250 KB)、快速。RDO具备基本的ODBC处理方法,可直接执行大多数ODBC API函数,RDO包含在VB 4.0/VB 5.0企业版中,由MSRDO32.DLL动态连接库来实现。RDO是综合了DAO/Jet、VBSQL/DBLib和ODBC的优点的对象模型,包含ODBC API应用层,设计为在后台(服务器端)有数据库存在的前提下运行,是针对SQL Server和Oracle而特别设计的。RDO的优势在于它完全被集成在VB之中,可直接访问SQL Server存储过程、完全支持T-SQL、T-SQL调试集成在开发环境中、Visual Database Tools的集成化等。但微软已宣布今后不再对VBSQL/DBLib进行升级,而ODBC API函数一般的编程方式也不为人们所喜爱,RDO的应用将逐渐减少。至于实际使用哪一种接口方式,在很大程度上依赖于用户的应用程序的具体情况而定。  
.B.Z^:]N
Gv%^DOIT博客

Bf"N9\N        z4rDOIT博客Fn`.K)m
W

四、VisualBasic访问数据库的前景 3V1qz^8[ zq$Q

|N;uaX;Pspace.doit.com.cn
5Hkb#B.MRspace.doit.com.cn近来随着Web应用软件的迅速发展和现有数据存储形式的多种多样,Visual Basic访问数据库的解决方案面临诸如快速提取分布于企业内部和外部有用商业信息等的多种挑战。为此Microsoft提出一种新的数据库访问策略,即“统一数据访问”(UniversalDataAccess)的策略。“统一数据访问”提供了高性能的存取包括关系型和非关系型在内的多种数据源,提供独立于开发工具和开发语言的简单的编程接口,这些技术使得企业集成多种数据源、选择更好的开发工具、应用软件、操作平台、建立容易维护的解决方案成为可能。 DOIT传媒 - DOIT论坛 | 探讨中国企业信息化,主要讨论IT基础架构相关资讯、解决方案、成功案例、行业应用和技术分析等,涉及存储、服务器、网络、安全、软件和中小企业等领域。 v4H|v@9`\I
DOIT博客/DI HE)[Ts

R|(L!X}T2z“统一数据访问”的基础是Microsoft的数据访问组件。这些组件包括ActiveXDataObjects(ADO)、RemoteDataService(RDS,也称“高级数据连接器或”ADC)、OLEDB和ODBC。
心情归类发布于2006-12-02 09:53:14
看一下
diuliao发布于2007-03-25 16:43:22
比较详细,ADO 比较常用。
我来说两句

(可选)

日历

« 2009-01-08  
    123
45678910
11121314151617
18192021222324
25262728293031

数据统计

  • 访问量: 21148
  • 日志数: 114
  • 图片数: 9
  • 建立时间: 2006-09-07
  • 更新时间: 2008-09-19

RSS订阅

Open Toolbar