亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Delphi > 正文

在DELPHI程序中使用ADO對象存取ODBC數據庫

2019-11-18 18:54:11
字體:
來源:轉載
供稿:網友
作為一個asp愛好者,筆者經常在ASP頁面中使用ADO對象操作ODBC數據庫,覺得用ASP創建WEB應用系統確定挺方便的.雖然在編程生涯中,筆者更喜歡Borland系列產品,對微軟產品有點排斥,對ASP卻是例外.某天,靈機一動,ADO對象是一個標準OLE對象,如果在DELPHI應用程序中能利用ADO操作數據庫,應該挺不錯.尤其在用DELPHI做網絡數據庫應用程序時,如果所在的WEB站點是WINNT站點并且支持ASP頁面,就可以用ADO對象訪問ODBC數據庫,而不用把那么大的BDE再上載到站點上去,這樣就可充分利用DELPHI和ASP的編程優勢,做出更好的ISAPI/NSAPI/CGI.

---- 經過編程和測試,在DELPHI中可以成功地用ADO對象存取ODBC數據庫,現將使用經驗寫出來,與大家共享,讓我們多一個訪問ODBC數據庫的方法.

----   在32位的DELPHI中,可以聲明一個variant變量(如AVariant),然后通過CreateOleObject 創建一個OLE對象,如AVariant:=CreateOleObject('ADODB.Connection')可以獲得一個數據庫連接對象的實例,然后就可以利用該對象的方法和屬性來操作ODBC數據庫了.

----   下面簡單介紹一下訪問ODBC數據庫所用到的ADO對象及其方法和屬性.

----  ?。保當祿爝B接對象(ADODB.Connection)

---- 該對象用于與ODBC數據庫建立連接,所有對數據庫的操作均通過該連接進行.

---- 數據庫連接對象ADODB.Connection的作用象Delphi中的TDatabase對象.

---- 建立一個連接對象的方法為(AConnection為Variant類型變量):

---- AConnection:=CreateOleObject('ADODB.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 Driver(*.mdb),是可選參數

---- SERVER :要打開的數據庫所在的服務器名稱,本機可用(local),是可選參數

---- DATABASE:要打開的數據庫名稱,是可選參數

---- UID   :用戶名稱,用來訪問數據庫,是可選參數

---- PWD   :用戶密碼,用來訪問數據庫,是可選參數

---- 以上參數均為可選參數,但必須提供足夠的信息來描述一個系統數據源.

---- 假如已經定義了一個ODBC的系統DSN,名稱為MyDsn,那么就可用以下語句建立一個數據庫連接:

----

		AConnection.Open('DSN=MyDsn');

 

---- 為了防止DSN不存在或其設置被他人修改時造成應用程序運行錯誤,可以用ADODB.Connection創建一個臨時ODBC數據源,這樣可以保證我們使用的系統DSN的參數設置是正確的.下面的語句可以創建一個臨時ODBC系統DSN,對應一個ACCESS數據庫,路徑為

C:Inetpubwwwroot	est.mdb AConnection.open('Driver={Microsoft Access Driver (*.mdb)};DBQ=C:inetpubwwwroot	est.mdb')

 

---- 建立一個ADODB.Connection后,如果不需要返回操作結果(如刪除,修改,更新等操作)就可以對數據庫進行正常的SQL操作了,此時應用ADODB.Connection的另外一個方法Execute,使用語法為:

AConnection.Execute( strSQL );

 

---- 其中strSQL為執行操作的SQL語句,如刪除操作可以為:delete from wfjcommu 用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相比較如下(具體請見ASP幫助文件):

		eof,bof:eof,bof.		MoveFirst, MoveLast:First, Last		MovePrevious, MoveNext:Prior, Next		Move:MoveBy		AddNew:append		Update:Post		Close:close

---- Delete加Update:delete,所有對數據表的修改均須用Update使操作有效,這與Delphi不同

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

 

----  ?。常渌R妼ο?與Delphi對應的對象):

----

	ADODB.Field:TField	ADODB.Parameter:TPara	ADODB.Error:EDBEngineError	ADODB.Command:無	ADODB.Property:無

 

----   下面來看一個應用例子,聽別人說總不如自己看實際的例子來體會。在這個例子中,將演示如何利用ADO對象來對一個數據表進行查詢、增加記錄、修改記錄和刪除記錄操作。具體的用法請參見程序中的注釋,如果有點Delphi數據庫編程經驗,相信不難理解。

----   在我們的例子使用的數據庫為Test.MDB,其中有一個數據表為wfjcommu,有五個字段AName、Portable、Tel、BP、PostAddress,分別表示姓名、手機號、電話號碼、呼機號碼和通信地址。

----

procedure TForm1.Button1Click(Sender: TObject);{*****************************************************

 

---- 用ADO操作ODBC數據庫本程序中,將創建一個臨時的ODBC系統數據源,指向一個MsAccess數據庫,然后對其中的數據表進行顯示、增加、修改、刪除和查詢操作注意:請在Uses語句中包含ComObj單元

*****************************************************}const{ 一些常量聲明,詳細請參見adovbs.inc }{ ---- CommandType的常量說明 ---- } adCmdUnknown = 0008;//未知,需要系統來判斷,速度慢,為缺省值 adCmdText = 0001;//命令語句如SQL語句 adCmdTable = 0002;//數據表名稱 adCmdStoredProc = 0004;//存儲過程名稱{ ---- CursorType的常量說明 ---- } adOpenForwardOnly = 0;//只能由前向后單向訪問,為缺省值 adOpenKeyset = 1;//可見其他用戶對數據的修改,但對其它用戶的增加和刪除不可見 adOpenDynamic = 2;//其他用戶對數據的增加修改和刪除均可見 adOpenStatic = 3;//其他用戶對數據的增加修改和刪除均不可見{---- LockType的常量說明 ---} adLockReadOnly = 1;//只讀,為缺省值 adLockPessimistic = 2;//在修改時,按單個記錄鎖定 adLockOptimistic = 3;//在修改后更新時,按單個記錄鎖定 adLockBatchOptimistic = 4;//在成批更新時記錄鎖定var AConnection, ARecordSet : variant; longintTemp : integer; strTemp : string; intIndex : integer;begin  {創建一個臨時的ODBC數據源,  指向一個MsAccess數據庫,  并利用此DSN建立一個數據庫連接}  AConnection := CreateOleObject('ADODB.Connection');  AConnection.Open('Driver={Microsoft Access Driver   (*.mdb)};DBQ=C:inetpubwwwroot	est');  {建立一個數據集對象,并從數據表中提取數據}  ARecordSet := CreateOleObject('ADODB.RecordSet');  ARecordSet.open( 'wfjcommu',AConnection,  adOpenStatic,adLockOptimistic,adCmdTable );  memo1.lines.clear;  memo1.lines.add('********數據表原有的內容如下********');  {顯示各個域的域名}  strTemp := ';  for intIndex := 0 to ARecordSet.Fields.count - 1 do   strTemp := strTemp + ARecordSet.Fields[intIndex].name+';';  memo1.lines.add( strTemp );  {顯示各個域的內容}  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.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  memo1.lines.add('********增加了一條       記錄后的數據表的內容如下********');  {顯示各個域的內容}  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.MoveLast;  ARecordSet.Fields['AName'] := '11';   //以FieldByName的方式存取  ARecordSet.Fields['Portable'] := '22';  ARecordSet.Fields(2) := '33';  //以Fields[index]的方式存取  ARecordSet.Fields(3) := '44';  ARecordSet.Fields(4) := '55';  ARecordSet.Update;//更新,Post  ARecordSet.MoveFirst;//移到首條,First  memo1.lines.add('********修改了最后一條   記錄后的數據表的內容如下********');  {顯示各個域的內容}  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.MoveLast;//移到末條,Last  ARecordSet.delete;//刪除,delete  ARecordSet.Update;//更新,在Delphi不需要  ARecordSet.MoveFirst;//移到首條,First  memo1.lines.add('********刪除了最后一條  記錄后的數據表的內容如下********');  {顯示各個域的內容}  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;{關閉數據集}  {用SQL語句進行查詢,查詢姓名為“張三”的記錄}  {注意,在SQL語句中,字符串應該用單引號包括起來}  ARecordSet.open( 'select * from wfjcommu   where AName = '張三'',      AConnection,adOpenStatic,adLockOptimistic,    adCmdText );  memo1.lines.add('********張三的內容如下********');  memo1.lines.add( '共有' + IntToStr  ( ARecordSet.RecordCount ) + '條匹配的記錄' );  {顯示各個域的內容}  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;  AConnection.close;end;

上一篇:談用Delphi程序獲取撥號連接的動態IP地址

下一篇:用Word做Delphi報表輸出工具

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97超视频免费观看| 成人免费高清完整版在线观看| 中文字幕欧美日韩| 96精品视频在线| 成人在线一区二区| 亚洲成人黄色网址| 亚洲一区二区日本| 久久久久久久久久久免费| 日韩综合中文字幕| 最近更新的2019中文字幕| 麻豆国产va免费精品高清在线| 精品国产自在精品国产浪潮| 欧美精品videos性欧美| 欧美成人免费全部| **欧美日韩vr在线| 国产成人高清激情视频在线观看| 久久精品视频播放| 国产成一区二区| 亚洲香蕉av在线一区二区三区| 视频在线观看99| 欧美一区二区三区……| 精品高清美女精品国产区| 日韩欧美精品在线观看| 久久久久这里只有精品| 欧美午夜精品久久久久久浪潮| 欧美日韩成人免费| 中文字幕久热精品在线视频| 色婷婷综合久久久久| 国产精品一区二区电影| 久久国产精品网站| 国产精品一区二区三区成人| 欧美激情图片区| 国产精品自产拍在线观看| 啊v视频在线一区二区三区| 日韩有码片在线观看| 日韩极品精品视频免费观看| 欧美成人激情图片网| 亚洲欧洲xxxx| 国产成人亚洲综合青青| 精品中文视频在线| 日韩av在线网| 国产区精品视频| 欧洲精品毛片网站| 国产欧美欧洲在线观看| 久久久久久久一区二区| 精品福利一区二区| 日本欧美国产在线| 国产一级揄自揄精品视频| 日韩在线国产精品| 国产精品丝袜一区二区三区| 91av视频导航| 日韩精品在线影院| 国产精品精品久久久| 欧美大片在线看免费观看| 2019亚洲男人天堂| 日韩视频在线免费| 国产精品27p| 成人97在线观看视频| 久久久欧美精品| 亚洲人成自拍网站| 色偷偷88888欧美精品久久久| 亚洲美女性视频| 国产日韩精品电影| 色偷偷88888欧美精品久久久| 欧美富婆性猛交| 亚洲人成人99网站| 色悠悠国产精品| 国产美女精彩久久| 97人人做人人爱| 一区三区二区视频| 久久在线免费观看视频| 青青草原成人在线视频| 亚洲另类激情图| 久久精品国产久精国产一老狼| 成人免费网站在线观看| 国产一区私人高清影院| 中文欧美在线视频| 国产亚洲视频中文字幕视频| 欧美日韩中文在线观看| 国产精品久久久久久久久久久久久| 狠狠做深爱婷婷久久综合一区| 久久久久久18| 国产精品入口福利| 国产精品午夜国产小视频| 色偷偷9999www| 国产亚洲一区二区精品| 久久精品青青大伊人av| 综合国产在线视频| 亚洲人成网7777777国产| 日韩专区中文字幕| 国产一区二区免费| 日韩av高清不卡| 美女视频黄免费的亚洲男人天堂| 欧美丝袜第一区| 日韩免费观看网站| 亚洲第一免费网站| 成人av资源在线播放| 色爱精品视频一区| 欧美成人手机在线| 精品中文字幕在线| 91久久久久久久一区二区| 国产成人综合av| 97色在线播放视频| 91精品国产91久久久| 亚洲新中文字幕| 8090成年在线看片午夜| 97av在线视频免费播放| 国产精品第一区| 国产精品热视频| 国产成一区二区| 91久热免费在线视频| 国产欧美 在线欧美| 国语自产精品视频在线看一大j8| 国产亚洲精品一区二区| 夜夜嗨av一区二区三区四区| 欧美老女人性视频| 国产精品6699| 亚洲精品资源美女情侣酒店| 9.1国产丝袜在线观看| 精品国产91久久久| 国产精品1区2区在线观看| 日韩毛片在线观看| 国产+成+人+亚洲欧洲| 日韩av中文字幕在线免费观看| 久久99热精品| 亚洲第一区中文字幕| 久久亚洲精品网站| 尤物九九久久国产精品的特点| 蜜臀久久99精品久久久无需会员| 一区二区三区无码高清视频| 69视频在线免费观看| 97精品国产97久久久久久免费| 热99精品里视频精品| 人人做人人澡人人爽欧美| 亚洲色图五月天| 日韩欧美高清在线视频| 久久视频在线直播| 久久久www成人免费精品张筱雨| 欧美日韩999| 欧美成年人视频网站欧美| 人妖精品videosex性欧美| 中文字幕精品www乱入免费视频| 国产日韩精品入口| 91精品国产高清自在线看超| 日韩在线视频国产| 欧美日韩国产精品| 国产欧美久久久久久| 黄色精品一区二区| 亚洲男人天堂古典| 亚洲男人天堂2024| 久久综合国产精品台湾中文娱乐网| 国产视频在线一区二区| 久久综合久久美利坚合众国| 亚洲激情第一页| 日韩在线中文字| 色婷婷综合久久久久中文字幕1| 国产精品海角社区在线观看| 日韩天堂在线视频| 国产精品国产三级国产aⅴ浪潮| 久久艹在线视频| 国产日韩精品一区二区| 91高清免费在线观看| 91在线观看免费观看| 91欧美精品成人综合在线观看|