ADODB.Connection、ADODB.RecordSet vba adodb.connection

1.数据库连接对象(ADODB. Connection)
该对象用于与ODBC数据库建立连接,所有对数据库的操作均通过该连接进行。
数据库连接对象ADODB. Connection的作用象Delphi中的TDatabase对象。
建立一个连接对象的方法为(AConnection为Variant类型变量):

AConnection:=CreateOleObject(’A DODB.Connection’)

用于建立连接的方法为Open,使用语法为(以对象AConnection为例):
AConnection.Open( ConnectionString, UserId, Password )

  三个参数均为字符串类型,其中UserId和Password为用户名称和用户密码,用于访问数据库使用时可以省略,因为在ConnectionString同样可以指定用户名称和用户密码。ConnectionString是用来说明ODBC数据源信息的字符串,其格式为:
’Provider=ProviderName; DSN=DSNName; DRIVER=driver; SERVER=server;DATABASE=database; UID=user; PWD=password’

其中:
Provider:数据提供者,默认状态下为MSDASQL,为微软OLEDB,通常省略;
DSN:要打开的数据库对应的OBDC系统数据源(DSN),是可选参数;
DRIVER:要打开的数据库所用的驱动程序名称,如Access对应Microsoft Access Driv(*.mdb),是可选参数;
SERVER:要打开的数据库所在的服务器名称,本机可用(local),是可选参数;
DATABASE:要打开的数据库名称,是可选参数;
UID:用户名称,用来访问数据库,是可选参数;
PWD:用户密码,用来访问数据库,是可选参数。
以上参数均为可选参数,但必须提供足够的信息来描述一个系统数据源。
  建立一个ADODB.Connection后,如果不需要返回操作结果(如删除,修改,更新等操作)就可以对数据库进行正常的SQL操作了,此时应用ADODB.Connection的另外一个方法Execute,使用语法为:
AConnection.Execute( strSQL );
  其中strSQL为执行操作的SQL语句,如删除操作可以为:delete fromwfjcommu。用AConnection.Close关闭一个数据库连接。
---------------------------------------------------------------------------------------------------------------

2、数据集对象(ADODB. RecordSet)
如果要执行查询操作并返回查询结果,或者要更方便地操作数据表,那就需要用到数据集对象了。
数据集对象ADODB.RecordSet的作用象Delphi中的TTable或TQuery对象。
建立一个数据集对象的方法为(ARecordSet为Variant类型变量):

ARecordSet:=CreateOleObject ('ADODB.RecordSet')

从数据表取得数据的方法为Open方法,具体使用方法为:
ARecordSet.Open( strCommand,ActiveConnection,intCursorType,intLockType, intCommandType );


其中:
strCommand:字符串,为命令参数,可以是一个Table名称,可以是一个SQL语句,也可以是一个服务器上的存储过程(StoredProc)名称,具体需要后面的参数intCommandType来指定。
ActiveConnection:要使用的数据库连接,是一个ADODB. Connection对象。
intCursorType:长整数,数据集的Cursor类型,可选参数,请参见程序中注释。
intLockType:长整数,对数据表的加锁类型,可选参数,请参见程序中注释。
intCommandType:长整数,命令参数的类型,用来指明strCommand的作用,可以指定strCommand为命令(如SQL语句)或数据表(TTable)或储存过程(StoredProc),可选参数,请参见程序中注释。

如执行一个SQL查询,可以采用如下语句:

ARecordSet.Open(’Select * from wfjcommu’,adOpenStatic,adLockOptimistic,adCmdText);

其它常见属性和方法与TTable和TQuery相比较如下 eof,bof,MoveFirst, MoveLast, First,MoveNext, close, Delete.

Fields[FieldNo]: Fields[FieldNo]
Fields['FieldName']: FieldByName('FieldName')

----------------------------------------------------------------------

3、其他常见对象(与Delphi对应的对象):
ADODB.Field: TField; ADODB.Parameter: TPara; ADODB.Error:EDBEngineError
ADODB.Command:无 ADODB.Property:无
下面来看一个应用例子:
procedure TForm1.Button1Click(Sender: TObject);
{*****************************************************
用ADO操作ODBC数据库
  本程序中,将创建一个临时的ODBC系统数据源,指向一个MsAccess数据库,然后对其中的数据表进行显示、增加、修改、删除和查询操作
注意:请在Uses语句中包含ComObj单元
*****************************************************}
const{一些常量声明(delphi)}

{------常数含义-------------}
adStateClosed = $00000000;//对象出于关闭状态(默认值)
adStateOpen = $00000001;//对象是打开状态
adStateConnecting = $00000002;//正在连接数据源的状态
adStateExecuting = $00000004;//对象的Execute方法已经被调用
adStateFetching = $00000008;//返回行(ROW)到Recordset对象

adUseServer = $00000002;//客户端游标引擎
adUseClient = $00000003;//服务器端游标引擎

adModeReadWrite = $00000003;//连接是可读写的

adXactCursorStability = $00001000;//只允许读其他事物已提交的改变(默认值)

{---- CommandType的常量说明 ----}
adCmdText = $00000001;//命令语句如SQL语句
adCmdTable = $00000002;//数据表名称
adCmdStoredProc = $00000004;//存储过程名称
adCmdFile = $00000100;//和对象类型相应的文件名称adCmdUnknown =0008;//未知,需要系统来判断,速度慢,为缺省值


{---- CursorType的常量说明 ----}
adOpenForwardOnly = 0;//只能由前向后单向访问,为缺省值
adOpenKeyset = 1;//可见其他用户对数据的修改,但对其它用户的增加和删除不可见
adOpenDynamic = 2;//其他用户对数据的增加修改和删除均可见
adOpenStatic = 3;//其他用户对数据的增加修改和删除均不可见

{---- LockType的常量说明 ---}
adLockReadOnly = 1;//只读,为缺省值
adLockPessimistic = 2;//在修改时,按单个记录锁定
adLockOptimistic = 3;//在修改后更新时,按单个记录锁定
adLockBatchOptimistic = 4;//在成批更新时记录锁定
**************************************************************

var
AConnection, ARecordSet : OleVariant;
longintTemp : integer;
strTemp : string;
intIndex : integer;
begin
{创建一个临时的ODBC数据源,指向一个SQL Server数据库,并利用此DSN建立一个数据库连接}
Conn1 := CreateOleObject('ADODB.Connection');
Conn1.ConnectionString := 'Provider=SQLOLEDB.1;Persist SecurityInfo=True;Initial Catalog=' +
db + ';Data Source=' + host + ';Connect Timeout=5;' +
'Use Procedure for Prepare=1';
Conn1.Open(cnn.ConnectionString, usr, pwd, -1);

{建立一个数据集对象,并从数据表中提取数据}
ARecordSet := CreateOleObject(’ADODB.RecordSet’);
ARecordSet.Open('SELECT * FROM Table1, Conn1, adOpenStatic,adLockOptimistic, adCmdText);

{增加一个记录}
ARecordSet.AddNew;//增加,Append
ARecordSet.Fields[’AName’] := ’1’;//以FieldByName的方式存取
ARecordSet.Fields[’Portable’] := ’2’;
ARecordSet.Fields(2) := ’3’;//以Fields[index]的方式存取
ARecordSet.Fields(3) := ’4’;
ARecordSet.Fields(4) := ’5’;
ARecordSet.Update;//更新,Post
ARecordSet.MoveFirst;//移到首条,First

{修改最后一条记录}
ARecordSet.MoveLast;
ARecordSet.Fields[’AName’] := ’11’;//以FieldByName的方式存取
ARecordSet.Fields[’Portable’] := ’22’;
ARecordSet.Fields(2) := ’33’;//以Fields[index]的方式存取
ARecordSet.Fields(3) := ’44’;
ARecordSet.Update;//更新,Post
ARecordSet.MoveFirst;//移到首条,First

{删除最后一条记录}
ARecordSet.MoveLast;//移到末条,Last
ARecordSet.delete;//删除,delete
ARecordSet.Update;//更新,在Delphi不需要
ARecordSet.MoveFirst;//移到首条,First

{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := ’’;
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields[intIndex].value+’;’;
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end;

ARecordSet.Close;{关闭数据集}

{关闭数据集和数据库连接}
ARecordSet.close;
AConnection.close;
end;

  

爱华网本文地址 » http://www.413yy.cn/a/25101018/371124.html

更多阅读

ExcelVBA之快速上手 excel vba教程

Excel VBA之快速上手转载第一章VBA语言基础第一节 标识符一.定义标识符是一种标识变量、常量、过程、函数、类等语言构成单位的符号,利用它可以完成对变量、常量、过程、函数、类等的引用。二.命名规则1) 字母打头,由字母、数字和下划线

Server.CreateObject("adodb.recordset") vba adodb.recordset

set rs=Server.Createobject("adodb.recordset")//创建一个数据记录集 set rs as adodb.recordsetsql="Select * from Log"rs.open sql,conn,3,3//可读可写,可用set rs=conn.execute sql代替//rs.open sql,conn,1,1//只读rs.addnew/

在VBA中计算时间差 表格中时间差怎么计算

网上有很多方法,但其实都把问题复杂化了,就用VBA自带的datediff函数就可以了。这样算出来的时间对跨日计算、以及起始时间晚于开始时间的计算等常见问题也解决的很好。示例:iMinutes= DateDiff("n", beginTime, endTime)上句可得到从b

创建adodb.connection方法 vb adodb.connection

再支持“Let”和“Set”赋值语句(2)时间:2010-04-14 07:49来源:未知 作者:宏兴 点击:435次二、把上面的代码复制到.NET中(假设文件名为conn.aspx) %@ Page Language=vb AutoEventWireup=false Codebehind=Conn.aspx.vb Inherits=wuliu

Vlookup、Lookup都靠边,Mlookup函数来了!! vlookup range lookup

Vlookup是最常用到的查找函数,但它有很大的局限性。比如:只能查找第一个符合条件的值,无法任意位置查找和多条件查找等。于是,兰色用VBA编写了一个功能强大的Mlookup函数。一、用法介绍=Mlookup(查找内容,查找区域,返回值所在的列数,第N

声明:《ADODB.Connection、ADODB.RecordSet vba adodb.connection》为网友花心坏男分享!如侵犯到您的合法权益请联系我们删除