久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区


曙海教育集團論壇開發語言培訓專區VB語言 → 語言創新 VB 6.0與大型數據庫的無“數據源”連接


  共有8355人關注過本帖樹形打印

主題:語言創新 VB 6.0與大型數據庫的無“數據源”連接

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個性首頁 | 博客 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發短信
等級:青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊:2010-11-12 11:08:23
語言創新 VB 6.0與大型數據庫的無“數據源”連接  發帖心情 Post By:2010-12-14 13:59:46

 目前,絕大多數的數據庫參考書都介紹了ODBC的手工配置方法,或者介紹了如何在代碼中進行ODBC配置。但這兩種方法都有一定的局限性: 不是當程序最終完成并分發到用戶手中后,還需要為用戶配置ODBC,顯得既麻煩又不符合專業軟件的要求;就是得編寫復雜的更改操作系統注冊表文件的程序,十分煩瑣。本文從ADO(ActiveX Data Objects)入手,介紹無需配置數據源的幾種常用大型數據庫連接方法。

本文所述的無“數據源”連接,意義不是不需要數據源,否則連接無從談起,而是不需要配置注冊數據源所進行的連接。ODBC(Open DataBase Connectivity,開放式數據庫連接)是用于連接不同數據源的標準編程語言接口。許多文章中介紹,在實現ODBC時,必須首先配置ODBC環境,進行數據源的注冊,然后才能在對數據庫編程時,對數據源進行連接、訪問和操作,并提供了用PB或VB等語言工具實現數據源注冊的具體方法。這些方法不但復雜煩瑣,而且由于參數內容不一,配置時令人感覺無所適從,不宜把握。

走近ADO

ADO是微軟提供的數據庫訪問技術。它被設計用來同新的數據訪問層OLE DB Provider一起協同工作,以提供通用數據訪問(Universal Data Access)能力。OLE DB是一個底層的數據訪問接口,用它可以訪問各種數據源,包括傳統的關系型數據庫、電子郵件系統及自定義的商業對象等。

ADO提供了一個熟悉的、高層的對OLE DB的Automation封裝接口。對那些熟悉RDO的程序員來說,可以把OLE DB看作ODBC驅動程序,如同RDO對象是ODBC驅動程序接口一樣,ADO對象是OLE DB的接口。同樣,像不同的數據庫系統需要它們自己的ODBC驅動程序一樣,不同的數據源也要求它們自己的OLE DB提供者(OLE DB provider)。目前,雖然OLE DB提供者比較少,但微軟正積極推廣該技術,并計劃用OLE DB取代ODBC。

微軟公司已宣布今后不會對VB SQL/DBLib進行升級,而且ODBC API函數一級的編程方式也不為人們所喜愛,所以,RDO今后將被以ActiveX技術為基礎的ADO所替代。ADO是基于OLE DB之上的技術,它通過內部的屬性和方法提供統一的數據庫訪問接口。

1.ADO組件

● Microsoft ActiveX Data Objects (ADO) :使客戶端應用程序能通過OLE DB提供者訪問和操作數據庫服務器中的數據。

● ActiveX Data Objects Extensions for DDL and Security(ADOX) :將ADO擴展為包括創建、修改和刪除的模式對象,如表格和過程,以及包括用于維護用戶和組以及管理對象權限的安全對象。

● ActiveX Data Objects (Multidimensional) (ADO MD): 將ADO擴展為包括指定到多維數據的對象,并允許瀏覽多維模式、查詢立方和檢索結果。

2.ADO優點

● ADO具有高度的靈活性,它可以使用相同的編程模式連接到不同的數據提供者,而不管給定提供者的特定特性。

● 較低的內存占用率。

● 具有遠程數據服務(RDS)功能,通過RDS可以在一次往返過程中將數據從服務器移動到客戶端應用程序或Web頁,并在客戶端對數據進行處理后將更新結果返回服務器。

● 同傳統的數據對象層次(DAO和RDO)不同,ADO可以獨立創建。可以只創建一個“Connection”對象,然后由多個獨立的“Recordset”對象來使用它。

● ODBC本身是以SQL Server、Oracle等關系數據庫作為訪問對象,而OLE DB則不僅限于此,它還可以對電子郵件、文本文件、復合文件、數據表等各種各樣的數據通過統一的接口進行存取。

OLE DB Provider for ODBC是ADO的默認提供者,默認值是MSDASQL,如果省略連接字符串的Provider=參數,ADO將試圖建立與該提供者的連接。

ADO的連接方式主要可分為OLE DB Privder方式與OLE DB Provider for ODBC方式。前者很明顯是微軟公司極力推薦的方式,對于ADO或RDS程序員來說,理想的環境是每個數據源都具有一個OLE DB接口,這比ODBC方式要快且所需資源更少。

ODBC Provider允許ADO連接到任何ODBC數據源。ODBC驅動程序對于當今使用的各種主要DBMS都有效,包括SQL Server、Access、FoxPro,以及諸如Oracle等非微軟數據庫產品。提供者將不受線程控制,允許使用Unicode,并將支持事務。

連接對象屬性

ConnectionString是Connection對象的屬性名稱,為可讀寫String類型,提供數據提供者或服務提供者打開到數據源的連接所需要的特定信息,包括Provider、Driver、Server、Database、DSN、UID、PWD或者Provider、Data Source、User、Password、Initial Catalog等。

1.Provider

字符串表達式,指定OLE DB數據或服務提供者的名稱,可以缺省。

一般有三種提供者:數據提供者、服務提供者和服務組件。數據提供者擁有自己的數據并將數據以表的格式顯示給應用程序。服務提供者將服務封裝,使ADO應用程序中的功能得以擴大。服務提供者也可以進一步定義為服務組件,服務組件必須連同其他服務提供者或組件一起工作。

2.Driver

字符串表達式,表示ODBC驅動程序的名稱,并不是ODBC驅動程序動態鏈接庫(DLL)的文件名。

有些驅動程序是微軟公司的產品,在安裝操作系統時就已經安裝好了; 而有些數據庫產品的驅動程序由開發數據庫產品的軟件公司隨數據庫產品一起提供,需要在安裝數據庫時選擇安裝后,才可以使用。如:Sybase數據庫驅動程序等。

3.Server(SRVR)

字符串表達式,數據庫服務名稱。

4.Database(DB)

字符串表達式,指定服務器上的數據庫名稱。即使DSN定義已經指定了數據庫,也可以在DSN之外指定Database參數以便連接到不同的數據庫。

5.DSN(Data Source)

字符串表達式,在此為空,無須指定連接的ODBC數據源的名稱。

6.UID(User ID)

字符串表達式,為ODBC數據源指定用戶標識(用戶賬號名),指定用戶必須有足夠的權限。

7.PWD(Password)

字符串表達式,為ODBC數據源指定用戶口令,必須有足夠的權限。

8.Persist Security Info

布爾類型,為True時,表明采用集成安全機制;若為False,則表明不采用集成安全機制。

無DSN(非DSN)連接

除了ADO所定義的參數外,提供者不支持任何特定連接參數,它將把任何非ADO連接參數傳遞給ODBC驅動程序管理器。下面介紹幾種常見數據庫的處理方法。

1. Visual Foxpro

[PROVIDER=MSDASQL.1]; ’或者為MSDASQL

DRIVER={Driver Name};

SourceDB=Path;

SourceType=DBF

例如:

cnna.ConnectionString = “PROVIDER=MSDASQL; ”

+ “DRIVER={Microsoft Visual Foxpro Driver};”

+ “SourceDB=D:\data\;”

+ “SourceType=DBF”

2.SQL Server

[PROVIDER=MSDASQL;]

DRIVER={Driver Name};

SERVER=server;

DATABASE=database;

UID=user;

PWD=password

例如:

cnnb.ConnectionString = “PROVIDER=

MSDASQL;”

+ “DRIVER={SQL Server};”

+ “SERVER=servera;”

+ “DATABASE=pubs;”

+ “UID=sa;”

+ “PWD=yyuui”

3. Sybase數據庫

[PROVIDER=MSDASQL;]

DRIVER={Driver Name};

SRVR=server; ’必須是SRVR,不能是SERVER

DB=database; ’可以是DB,也可以是DATABASE

DSN=; ’可以省略

UID=user;

PWD=passwod;

PERSIST SECURITY INFO=False

例如:

cnnc.ConnectionString=

“PROVIDER=MSDASQL;”

+ “DRIVER={Sybase System 11};”

+ “SRVR=serveru; ”

+ “DSN=;”

+ “DB=dataa;”

+ “UID=sa;”

+ “PWD=dqwe;”

+ “PERSIST SECURITY INFO=False”

4. Oracle數據庫

[PROVIDER=MSDASQL;]

DRIVER={Driver Name};

SERVER=server;

databasename=database;

databasefile=path;

DSN=;

UID=user;

PWD=password;

例如:

cnnd.ConnectionString =

“PROVIDER=MSDASQL; ”

+ “DRIVER={Microsoft ODBC for Oracle};”

+ “SERVER=Webserver;”

+ “DSN=;”

+ “databasename=dataall;”

+ “databasefile=d:\data\;”

+ “UID=dba;”

+ “PWD=killer”

應用實例

下面以Sybase 11.9.2為例,編制一個簡單的工作人員管理程序,介紹ADO的具體實現方法和步驟。數據庫名稱為Workerdb,只包括一個表(Worker),其結構如下:

字段名稱    寬度       注釋

code nchar(4) 代號

name char(8) 姓名

…… …… ……

首先安裝ADO,在VB的“工程”/“引用”對話框中選擇“ActiveX Data Object 2. 5 Library”(ADODB)。其中“ADO Recordset 2. 5 Library”是一個客戶端的版本(ADOR),因為不需要Connection對象來建立與遠程數據源的聯系,所以ADOR對于客戶端的數據訪問來說已經足夠了。 下面是部分主要代碼:

1. 處理代碼

’在工程菜單中引用Microsoft ActiveX Data Object 2. 5 Library

’聲明ADO連接對象為工程級全局變量

Public cndbase As New ADODB.Connection

……

’自定義連接數據庫函數

Public Function ConnectDbase(StrConnect As String) As Boolean

On Error GoTo ErrHandle

cndbase.ConnectionString = StrConnect

cndbase.Open

cndbase.CursorLocation = adUseClient

ConnectDbase = True

Exit Function

ErrHandle:

ConnectDbase = False

End Function

Private Sub Form_Load()

……

輸入 VarServer ’服務名稱

VarDbase ’數據庫名稱

VarUser ’用戶名稱

VarPassword ’用戶口令

……

’連接數據庫,采取無DSN連接方法

StrConnect = “Provider=MSDASQL;”

+“Driver={” & VarDriver &“};”

+“SRVR=” & VarServer & “;”

+“DB=” & VarDbase & “;”

+“DSN=;”

+“UID=” & VarUser & “;”

+“PWD=” & VarPassword & “;”

+ “Persist Security Info=False” ’不采用集成安全機制

if ConnectDbase(StrConnect) Then

Exit Sub

else

myexit = MsgBox(“數據庫連接失敗!請檢查連接設置信息。”, vbOKOnly, “錯誤提示:”)

Unload me

endif

ErrHand:

myexit = MsgBox(“錯誤程序:” & Err. Source & Chr(10) & “錯誤代碼:” & Err. Number & Chr(10) & “錯誤信息:” & Err.Description, VbAbortRetryIgnore, “錯誤提示:”)

If myexit = 3 Then

Err.Clear

Unload Me

Else

If myexit = 4 Then

Err.Clear

Resume

Else

Err.Clear

Resume Next

End If

End If

End Sub

Private Sub Form_Unload()

……

cndbase.Close

Set cndbase = Nothing

End Sub

2. 建表

codbase.CommandText=“{call CREATABLE (?) }”

codbase.CommandType = adCmdText

codbase.Name = “CREATABLE”

’設定OutPut的參數

Set param = codbase.CreateParameter(“flag”, adInteger, adParamOutput)

codbase. Parameters. Append param

Set codbase. ActiveConnection = cndbase

codbase. Execute

If codbase. Parameters(0) = 0 Then

myexit = MsgBox(“建表成功!”, vbOKOnly, “程序提示:”)

Else

myexit = MsgBox(“建表失敗!”, vbOKOnly, “錯誤提示:”)

Endif

……

3. 修改

rsdbase. Open“worker”,cndbase,adOpenDynamic,adLockPessimistic,adCmdTable

rsdbase. MoveFirst

cndbase. BeginTrans

’在記錄集中進行循環更改

Do Until rsdbase.EOF

’增加20元職務代碼為1的人員的工資

If rsdbase! duty = 1 Then

rsdbase! salary = rsdbase! salary + 20

End If

rsdbase. MoveNext

Loop

rsdbase.UpdateBatch

……

4. 統計

StrSQL = “Select avg(salary), sum(salary) from worker”

rsdbase. CursorLocation = adUseClient

rsdbase. Open StrSQL,cndbase

salaryavg = rsdbase(0) ’平均工資

salarysum = rsdbase(1) ’工資總和

……

rsdbase .Close

5. 存儲過程creatable. sql

CREATE PROCEDURE dbo.creatable(@return_value integer output)

AS

Begin

Create table Workerdb..Worker

( code nchar(4) not null ,

name char(8) not null ,

year nchar(4) ,

month nchar(2) ,

day nchar(2) ,

salary numeric(18,2) ,

duty nchar(1) )

If @@error != 0

begin

select @return_value = 1

  End

 Else

Begin

select @return_value = 0

End

return

End

支持(0中立(0反對(0單帖管理 | 引用 | 回復 回到頂部

返回版面帖子列表

語言創新 VB 6.0與大型數據庫的無“數據源”連接








簽名
久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
亚洲美女视频一区| 亚洲精品免费在线观看| 欧美不卡激情三级在线观看| 日韩欧美国产三级| 国产精品影视天天线| 中文字幕中文乱码欧美一区二区| 国产精品国产亚洲精品看不卡15| 首页国产欧美日韩丝袜| 国产精品剧情在线亚洲| 国产婷婷一区二区| 欧美精品免费视频| 日韩一级免费观看| 日韩欧美国产综合在线一区二区三区| 在线国产亚洲欧美| 欧美连裤袜在线视频| 欧美午夜欧美| 亚洲va久久久噜噜噜久久狠狠| 欧洲成人一区二区| 在线免费观看不卡av| 色之综合天天综合色天天棕色| 六十路精品视频| 日本不卡一区| 91久久奴性调教| 7777精品伊人久久久大香线蕉完整版| 欧美日韩色一区| 欧美午夜在线一二页| www国产成人免费观看视频 深夜成人网| 日韩欧美成人午夜| 日韩欧美视频在线| 一区二区三区在线免费| 日韩精品三区四区| 国产主播一区二区三区| 成人在线视频电影| 日韩电影免费观看在| 一区二区三区国| 色综合久久九月婷婷色综合| 日韩精品一区二区三区中文不卡| 91免费精品国自产拍在线不卡| 国产精品自在在线| 国产欧美欧洲| 人偷久久久久久久偷女厕| 色婷婷精品大在线视频| 欧美一区二区在线视频| 欧美高清在线精品一区| 香蕉成人啪国产精品视频综合网| 另类专区欧美蜜桃臀第一页| 99理论电影网| 色婷婷综合久久久中文一区二区| 日韩你懂的电影在线观看| 亚洲三级在线免费观看| 国产成人午夜视频| 欧美大香线蕉线伊人久久国产精品| 色老汉一区二区三区| 国产精品每日更新在线播放网址| 天天综合日日夜夜精品| 成人激情免费网站| 欧美一区1区三区3区公司| 日韩欧美在线1卡| 国产精品超碰97尤物18| 天天综合日日夜夜精品| 国产精品天干天干在观线| 日韩美女久久久| 国内精品久久久久影院一蜜桃| 国产乱码精品一区二区三区卡| 亚洲国产欧洲综合997久久| 91麻豆精品国产91久久久久久久久| 国产精品卡一卡二卡三| 久久精品国产99久久6| 成人免费观看网站| 91福利小视频| 中文字幕在线视频一区| 国产精品一区二区久激情瑜伽| 韩国一区二区三区美女美女秀| 欧洲一区在线观看| 亚洲欧洲精品成人久久奇米网| 国产精品一二三在| 欧美色图激情小说| 一区二区三区 在线观看视频 | 中文字幕一区二区日韩精品绯色 | 成人va在线观看| 天堂资源在线亚洲资源| 国产精品色婷婷| 69久久夜色精品国产69蝌蚪网| 亚洲精品欧美激情| 国产精品福利av| 99久久夜色精品国产网站| 欧美精品乱码久久久久久| 日韩精品电影在线观看| 亚洲精品一区二区三区av| 亚洲精品乱码久久久久久黑人| 国产精品久久久对白| 久久婷婷成人综合色| 成人开心网精品视频| 7777女厕盗摄久久久| 国产精品一区在线| 日韩视频一区二区三区| 国产成人在线视频网站| 欧美一区二区三区系列电影| 国产精品一卡二卡在线观看| 欧美久久一区二区| 国产成人精品网址| 欧美一级xxx| 成人av在线影院| 精品国产伦一区二区三区观看体验| 懂色av中文一区二区三区| 日韩午夜激情免费电影| a级高清视频欧美日韩| 久久久国产午夜精品| 91精品免费| 亚洲欧美综合另类在线卡通| 久久伊人资源站| 亚洲sss视频在线视频| 色天天综合色天天久久| 麻豆精品新av中文字幕| 69精品人人人人| 99久久久精品免费观看国产蜜| 国产欧美日韩另类一区| 欧美亚洲免费高清在线观看| 香蕉久久夜色精品国产使用方法| 91成人网在线| 成人精品视频一区二区三区尤物| 国产亚洲欧洲997久久综合| 波多野结衣久草一区| 亚洲制服丝袜在线| 欧美最猛黑人xxxxx猛交| 国产福利一区在线观看| 国产色91在线| 欧洲精品一区色| 日韩精品欧美成人高清一区二区| 欧美在线观看视频一区二区三区| 懂色av一区二区三区免费看| 久久久久9999亚洲精品| 欧美美乳视频网站在线观看| 亚洲香肠在线观看| 欧美在线短视频| 91丨porny丨户外露出| 亚洲精品欧美激情| 91国产丝袜在线播放| jlzzjlzz亚洲女人18| 中文字幕在线视频一区| 一本大道av一区二区在线播放| 国产成人精品网址| 中文字幕制服丝袜一区二区三区 | 成人av电影在线观看| 国产精品美女一区二区在线观看| 色综合666| 国产成都精品91一区二区三| 国产精品久久久久久久蜜臀| 中文字幕免费在线不卡| 不卡欧美aaaaa| 亚洲精品美国一| 欧美一区二区性放荡片| 久精品国产欧美| 老司机精品视频线观看86 | 一区二区理论电影在线观看| 久久精品日产第一区二区三区高清版| 超碰97在线资源| 免费成人av资源网| 久久噜噜亚洲综合| 中文字幕久久综合| 91色|porny| 日韩av二区在线播放| 久久色.com| 欧亚一区二区三区| 欧美二级三级| 国产999精品久久| 一区二区三区**美女毛片| 欧美一区二区网站| 先锋影音网一区| 成人在线观看网址| 国产精品一级在线| 午夜国产不卡在线观看视频| 欧美国产精品中文字幕| 69堂国产成人免费视频| 亚洲欧美在线网| 国产一区二区在线观看免费播放| 国产一区二区主播在线| 亚洲电影你懂得| 中文字幕亚洲综合久久菠萝蜜| 欧美一区二区三区在线观看视频| 亚洲国产精品毛片| 激情视频在线观看一区二区三区| 国产激情一区二区三区| 日韩国产精品久久久| 中文字幕亚洲欧美在线不卡| 精品国产乱码久久久久久久久| 色综合婷婷久久| 日本不卡一区二区三区视频| av一区二区三区| 国产米奇在线777精品观看| 亚洲二区在线观看| 亚洲欧美日韩电影| 欧美激情一区二区三区蜜桃视频 | 欧美一区二区三区日韩| 色综合天天综合狠狠| 欧美日韩系列| 国产精品播放| 91丨九色porny丨蝌蚪| 国产精品18久久久久久久久| 午夜精品久久久久久|