主頁 > 知識(shí)庫(kù) > OLEDB和ODBC的區(qū)別(優(yōu)缺點(diǎn))

OLEDB和ODBC的區(qū)別(優(yōu)缺點(diǎn))

熱門標(biāo)簽:美國(guó)地圖標(biāo)注軟件下載 硅基電話機(jī)器人官網(wǎng) 西安電話自動(dòng)外呼系統(tǒng) 城市地圖標(biāo)志怎么標(biāo)注 電話機(jī)器人怎么看余額 合肥crm外呼系統(tǒng)加盟 怎么修改高德地圖標(biāo)注 長(zhǎng)沙外呼系統(tǒng)平臺(tái) 漯河電銷回?fù)芡夂粝到y(tǒng)
ODBC是一種連接數(shù)據(jù)庫(kù)的開放標(biāo)準(zhǔn)。

ODBC(OpenDataBase Connectivity,開放數(shù)據(jù)庫(kù)互連)是微軟公司開放服務(wù)結(jié)構(gòu)(WOSA,Windows OpenServices Architecture)中有關(guān)數(shù)據(jù)庫(kù)的一個(gè)組成部分,它建立了一組規(guī)范,并提供了一組對(duì)數(shù)據(jù)庫(kù)訪問的標(biāo)準(zhǔn)API(應(yīng)用程序編程接口)。這些API利用SQL來完成其大部分任務(wù)。ODBC本身也提供了對(duì)SQL語言的支持,用戶可以直接將SQL語句送給ODBC。
它本身就是為了是數(shù)據(jù)庫(kù)的使用者不必考慮使用的是何種數(shù)據(jù)庫(kù)而只需要相同的操作而設(shè)計(jì)的。

ODBC是Open Database Connect即開放數(shù)據(jù)庫(kù)互連的簡(jiǎn)稱,它是由Microsoft 公司于1991 年提出的一個(gè)用于訪問數(shù)據(jù)庫(kù)的統(tǒng)一界面標(biāo)準(zhǔn),是應(yīng)用程序和數(shù)據(jù)庫(kù)系統(tǒng)之間的中間件。它通過使用相應(yīng)應(yīng)用平臺(tái)上和所需數(shù)據(jù)庫(kù)對(duì)應(yīng)的驅(qū)動(dòng)程序與應(yīng)用程序的交互來實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)的操作,避免了在應(yīng)用程序中直接調(diào)用與數(shù)據(jù)庫(kù)相關(guān)的操作,從而提供了數(shù)據(jù)庫(kù)的獨(dú)立性。
ODBC 主要由驅(qū)動(dòng)程序和驅(qū)動(dòng)程序管理器組成。驅(qū)動(dòng)程序是一個(gè)用以支持ODBC 函數(shù)調(diào)用的模塊,每個(gè)驅(qū)動(dòng)程序?qū)?yīng)于相應(yīng)的數(shù)據(jù)庫(kù),當(dāng)應(yīng)用程序從基于一個(gè)數(shù)據(jù)庫(kù)系統(tǒng)移植到另一個(gè)時(shí),只需更改應(yīng)用程序中由ODBC 管理程序設(shè)定的與相應(yīng)數(shù)據(jù)庫(kù)系統(tǒng)對(duì)應(yīng)的別名即可。驅(qū)動(dòng)程序管理器可鏈接到所有ODBC 應(yīng)用程序中,它負(fù)責(zé)管理應(yīng)用程序中ODBC 函數(shù)與DLL 中函數(shù)的綁定。
ODBC 使用層次的方法來管理數(shù)據(jù)庫(kù),在數(shù)據(jù)庫(kù)通信結(jié)構(gòu)的每一層,對(duì)可能出現(xiàn)依賴數(shù)據(jù)庫(kù)產(chǎn)品自身特性的地方,ODBC 都引入一個(gè)公共接口以解決潛在的不一致性,從而很好地解決了基于數(shù)據(jù)庫(kù)系統(tǒng)應(yīng)用程序的相對(duì)獨(dú)立性,這也是ODBC 一經(jīng)推出就獲得巨大成功的重要原因之一。

從結(jié)構(gòu)上分,ODBC 分為單束式和多束式兩類。

1.單束式驅(qū)動(dòng)程序

單束式驅(qū)動(dòng)程序介于應(yīng)用程序和數(shù)據(jù)庫(kù)之間,像中介驅(qū)動(dòng)程序一樣數(shù)據(jù)提供一個(gè)統(tǒng)一的數(shù)據(jù)訪問方式。當(dāng)用戶進(jìn)行數(shù)據(jù)庫(kù)操作時(shí),應(yīng)用程序傳遞一個(gè)ODBC 函數(shù)調(diào)用給ODBC 驅(qū)動(dòng)程序管理器,由ODBC API 判斷該調(diào)用是由它直接處理并將結(jié)果返回還是送交驅(qū)動(dòng)程序執(zhí)行并將結(jié)果返回。由上可見,單束式驅(qū)動(dòng)程序本身是一個(gè)數(shù)據(jù)庫(kù)引擎,由它直接可完成對(duì)數(shù)據(jù)庫(kù)的操作,盡管該數(shù)據(jù)庫(kù)可能位于網(wǎng)絡(luò)的任何地方。

2.多束式驅(qū)動(dòng)程序

多束式驅(qū)動(dòng)程序負(fù)責(zé)在數(shù)據(jù)庫(kù)引擎和客戶應(yīng)用程序之間傳送命令和數(shù)據(jù),它本身并不執(zhí)行數(shù)據(jù)處理操作而用于遠(yuǎn)程操作的網(wǎng)絡(luò)通信協(xié)議的一個(gè)界面。前端應(yīng)用程序提出對(duì)數(shù)據(jù)庫(kù)處理的請(qǐng)求,該請(qǐng)求轉(zhuǎn)給ODBC 驅(qū)動(dòng)程序管理器,驅(qū)動(dòng)程序管理器依據(jù)請(qǐng)求的情況,就地完成或傳給多束驅(qū)動(dòng)程序,多束式驅(qū)動(dòng)程序?qū)⒄?qǐng)求翻譯為特定廠家的數(shù)據(jù)庫(kù)通信接口(如Oracle 的SQLNet)所能理解的形式并交于接口去處理,接口把請(qǐng)求經(jīng)網(wǎng)絡(luò)傳送給服務(wù)器上的數(shù)據(jù)引擎,服務(wù)器處理完后把結(jié)果發(fā)回給數(shù)據(jù)庫(kù)通信接口,數(shù)據(jù)庫(kù)接口將結(jié)果傳給多束式ODBC 驅(qū)動(dòng)程序,再由驅(qū)動(dòng)程序?qū)⒔Y(jié)果傳給應(yīng)用程序。

ODBC(開放數(shù)據(jù)庫(kù)互連):是Microsoft引進(jìn)的一種早期數(shù)據(jù)庫(kù)接口技術(shù)。它實(shí)際上是ADO的前身。早期的數(shù)據(jù)庫(kù)連接是非常困難的. 每個(gè)數(shù)據(jù)庫(kù)的格式都不一樣,開發(fā)者得對(duì)他們所開發(fā)的每種數(shù)據(jù)庫(kù)的底層API有深刻的了解. 因此,能處理各種各樣數(shù)據(jù)庫(kù)的通用的API就應(yīng)運(yùn)而生了. 也就是現(xiàn)在的ODBC(Open Database Connectivity), ODBC是人們?cè)趧?chuàng)建通用API的早期產(chǎn)物. 有許多種數(shù)據(jù)庫(kù)遵從了這種標(biāo)準(zhǔn),被稱為ODBC兼容的數(shù)據(jù)庫(kù).

OLEDB(對(duì)象鏈接和嵌入數(shù)據(jù)庫(kù))位于ODBC層與應(yīng)用程序之間. 在你的ASP頁面里,ADO是位于OLEDB之上的"應(yīng)用程序". 你的ADO調(diào)用先被送到OLEDB,然后再交由ODBC處理. 你可以直接連接到OLEDB層,如果你這么做了,你將看到服務(wù)器端游標(biāo)(recordset的缺省的游標(biāo),也是最常用的游標(biāo))性能的提升.

參考 http://www.connectionstrings.com/

用odbc連接數(shù)據(jù)庫(kù):

odbc中提供三種dsn,它們的區(qū)別很簡(jiǎn)單:用戶dsn只能用于本用戶。系統(tǒng)dsn和文件dsn的區(qū)別只在于連接信息的存放位置不同:系統(tǒng)dsn存放在odbc儲(chǔ)存區(qū)里,而文件dsn則放在一個(gè)文本文件中。
它們的創(chuàng)建方法就不說了。

在asp中使用它們時(shí),寫法如下:

1.sql server:

用系統(tǒng)dsn: connstr="DSN=dsnname; UID=xx; PWD=xxx;DATABASE=dbname"
用文件dsn:connstr="FILEDSN=xx;UID=xx; PWD=xxx;DATABASE=dbname"
還可以用連接字符串(從而不用再建立dsn):
connstr="DRIVER={SQLSERVER};SERVER=servername;UID=xx;PWD=xxx"

2.access:

用系統(tǒng)dsn: connstr="DSN=dsnname"
(或者為:connstr="DSN=dsnname;UID=xx;PWD=xxx")
用文件dsn:connstr="FILEDSN=xx"
還可以用連接字符串(從而不用再建立dsn):
connstr="DRIVER={MicrosoftAccess Driver};DBQ=d:\abc\abc.mdb"

用oledb連接數(shù)據(jù)庫(kù):

1.sql server:
connstr="PROVIDER=SQLOLEDB;
DATASOURCE=servername;UID=xx;PWD=xxx;DATABASE=dbname"

2.access:
connstr="PROVICER=MICROSOFT.JET.OLEDB.4.0;
DATASOURCE=c:\abc\abc.mdb"

值得注意的是,OLE DB對(duì)ODBC的兼容性,允許OLE DB訪問現(xiàn)有的ODBC數(shù)據(jù)源。其優(yōu)點(diǎn)很明顯,由于ODBC相對(duì)OLE DB來說使用得更為普遍,因此可以獲得的ODBC驅(qū)動(dòng)程序相應(yīng)地要比OLE DB的要多。這樣不一定要得到OLE DB的驅(qū)動(dòng)程序,就可以立即訪問原有的數(shù)據(jù)系統(tǒng)。
提供者位于OLE DB層,而驅(qū)動(dòng)程序位于ODBC層。如果想使用一個(gè)ODBC數(shù)據(jù)源,需要使用針對(duì)ODBC的OLE DB提供者,它會(huì)接著使用相應(yīng)的ODBC驅(qū)動(dòng)程序。如果不需要使用ODBC數(shù)據(jù)源,那么可以使用相應(yīng)的OLE DB提供者,這些通常稱為本地提供者(native provider)。
可以清楚地看出使用ODBC提供者意味著需要一個(gè)額外的層。因此,當(dāng)訪問相同的數(shù)據(jù)時(shí),針對(duì)ODBC的OLE DB提供者可能會(huì)比本地的OLEDB提供者的速度慢一些。

ODBC,OLEDB連接字符串詳解

SQL Server

u ODBC
1. Standard Security:
"Driver={SQLServer};Server=Aron1;Database=pubs;Uid=sa;Pwd=asdasd;"
2. Trusted connection:
"Driver={SQLServer};Server=Aron1;Database=pubs;Trusted_Connection=yes;"
3. Prompt for username and password:
oConn.Properties("Prompt")= adPromptAlways
oConn.Open"Driver={SQL Server};Server=Aron1;DataBase=pubs;"

u OLE DB, OleDbConnection (.NET)

1. Standard Security:
"Provider=sqloledb;DataSource=Aron1;Initial Catalog=pubs;User Id=sa;Password=asdasd;"
2. Trusted Connection:
"Provider=sqloledb;DataSource=Aron1;Initial Catalog=pubs;Integrated Security=SSPI;"
(useserverName\instanceName as Data Source to use an specifik SQLServer instance,only SQLServer2000)
3. Prompt for username and password:
oConn.Provider= "sqloledb"
oConn.Properties("Prompt")= adPromptAlways
oConn.Open"Data Source=Aron1;Initial Catalog=pubs;"
4. Connect via an IP address:
"Provider=sqloledb;DataSource=190.190.200.100,1433;Network Library=DBMSSOCN;Initial Catalog=pubs;UserID=sa;Password=asdasd;"
(DBMSSOCN=TCP/IPinstead of Named Pipes, at the end of the Data Source is the port to use (1433is the default))

u SqlConnection (.NET)

1. Standard Security:
"DataSource=Aron1;Initial Catalog=pubs;User Id=sa;Password=asdasd;"
- or -
"Server=Aron1;Database=pubs;UserID=sa;Password=asdasd;Trusted_Connection=False"
(bothconnection strings produces the same result)
2. Trusted Connection:
"DataSource=Aron1;Initial Catalog=pubs;Integrated Security=SSPI;"
- or -
"Server=Aron1;Database=pubs;Trusted_Connection=True;"
(bothconnection strings produces the same result)
(useserverName\instanceName as Data Source to use an specifik SQLServer instance,only SQLServer2000)
3. Connect via an IP address:
"DataSource=190.190.200.100,1433;Network Library=DBMSSOCN;Initial Catalog=pubs;UserID=sa;Password=asdasd;"
(DBMSSOCN=TCP/IPinstead of Named Pipes, at the end of the Data Source is the port to use (1433is the default))
您可能感興趣的文章:
  • Turbolinux-7-Server拓林思服務(wù)器版光盤安裝過程詳細(xì)圖解
  • Moon_LServer Linux下一鍵搭建Apache+PHP+MySQL+Zend+PHPMyAdmin+GD庫(kù)的軟件
  • Red Hat 紅帽企業(yè)Linux 5 SERVER 正式版 迅雷下載地址
  • 關(guān)于php連接mssql:pdo odbc sql server
  • mysql odbc字符集設(shè)置(中文顯示亂碼)
  • ADO.NET 連接數(shù)據(jù)庫(kù)字符串小結(jié)(Oracle、SqlServer、Access、ODBC)
  • LVS(Linux Virtual Server)Linux 虛擬服務(wù)器介紹及配置(負(fù)載均衡系統(tǒng))
  • ADO,OLEDB,ODBC,DAO,RDO的區(qū)別說明
  • php5.3中連接sqlserver2000的兩種方法(com與ODBC)
  • linux mysql 報(bào)錯(cuò):MYSQL:The server quit without updating PID file
  • php常用ODBC函數(shù)集(詳細(xì))
  • Linux編譯mssql擴(kuò)展使用php連接sqlserver2008的使用步驟
  • Linux下用dnsmasq做dns cache server的配置方法
  • linux下如何配置SQLSERVER ODBC

標(biāo)簽:商洛 濟(jì)源 吉林 撫順 玉溪 瀘州 廣西 文山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《OLEDB和ODBC的區(qū)別(優(yōu)缺點(diǎn))》,本文關(guān)鍵詞  OLEDB,和,ODBC,的,區(qū)別,優(yōu)缺點(diǎn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《OLEDB和ODBC的區(qū)別(優(yōu)缺點(diǎn))》相關(guān)的同類信息!
  • 本頁收集關(guān)于OLEDB和ODBC的區(qū)別(優(yōu)缺點(diǎn))的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章