本页使用了标题或全文手工转换

Microsoft Jet Database Engine

维基百科,自由的百科全书
跳转至: 导航搜索

Microsoft Jet是微軟針對檔案型資料庫所發展的資料庫引擎(Database Engine),它的適用資料來源種類相當多,像是Microsoft AccessMicrosoft ExceldBase等等檔案型資料來源都可以利用Microsoft Jet資料庫引擎來使用SQL指令存取。

目前的Jet引擎最新版本為4.0,並且未來在x64平台上將不再支援。

Jet DLLs
Jet DLLs.svg
Jet version Jet engine DLL file name MDB version
1.1 1.10.0001 MSAJT110.DLL 1.0 / 1.1
2.0 (comlyr) 2.00.0000 MSAJT200.DLL 1.0 / 1.1 / 2.0
2.5(accsvc) 2.50.1606 MSAJT200.DLL 1.0 / 1.1 / 2.0 / 3.0
2.5(VB4 16) 2.50.1606 MSAJT200.DLL 1.0 / 1.1 / 2.0 / 3.0
3.0 3.0.0.2118 MSJT3032.DLL 1.0 / 1.1 / 2.0 / 3.0
3.5 MSJET35.DLL 1.0 / 1.1 / 2.0 / 3.0
4.0 (SP8) 4.0.8015.0 MSJET40.DLL 1.0 / 1.1 / 2.0 / 3.0 / 4.0
Application/Version Jet version
Microsoft Access 1.0 1.0
Microsoft Access 1.1 1.1
Microsoft Access 2.0 2.0
Microsoft Access 2.0 2.5 with Microsoft Access Service Pack
Microsoft Access 7.0 3.0
Microsoft Access 97 3.5 with Office 97
Microsoft Access 97 SR1 3.5 with Office 97SR1
Visual Basic 3.0 1.1
Visual Basic 3.0 2.0 with Visual Basic Compatibility Layer
Visual Basic 3.0 2.5 with Microsoft Access Service Pack
Visual Basic 4.0 16-bit 2.5
Visual Basic 4.0 32-bit 3.0
Visual Basic 5.0 32-bit 3.0
Visual Basic 5.0 32-bit 3.5
Visual C++ 4.X 3.0
Visual C++ 5.0 3.5
Jet 3.51(web download) 3.51(3.5 Binary compatible)
Microsoft Access 2000 Standard Edition
Microsoft Access 2002 Standard Edition
Microsoft Access 2003 Standard Edition
4.0

版本歷程[编辑]

Jet 1.0[编辑]

Microsoft Jet第一個版本是在1992年研發出來,當時的研發代號是「Cirrus」,為Microsoft Access 1.0所使用的資料庫引擎,當時的資料存取元件為DAO(Data Access Object),程式語言為Visual Basic 3.0,DAO本身是一個COM元件,可以由支援COM規格的程式語言所存取,但它當時的功能只適用於Microsoft Access。Jet 1.1於1993年5月發表,首次支援Access以外的資料庫 (FoxPro)[1]

Jet 2.x[编辑]

Jet 2.0在1994年4月與Access 2.0一起發表,它支援了資料完整性,引擎層次資料驗證,ANSI SQL,聯合查詢,子查詢等等功能,DAO也新增了更多完整的物件能力,像是集合、物件、屬性和方法等。同年的10月份,Jet 2.5與Access 2.0 Service Pack和ODBC Desktop Database Driver Kit一起發表,它也是第一個32位元版本的Jet引擎,並開始支援Excel的讀寫能力以及VBA的功能[1]

Jet 3.x[编辑]

Jet 3.0在1995年第三季發表,Jet 3.5則是在1996年第三季發表,與Jet 2.x不同的是,它只有32位元的版本,提供給Windows 95以及Windows NT等作業系統使用,其主要新功能為支援資料庫複製(Replication),多執行緒支援以及動態緩衝區 (dynamic buffer)的能力,並使用全新的索引機制,可加快資料庫的速度,並且擴充DAO的物件模型[1]

Jet 4.0[编辑]

Jet 4.0是Microsoft發表的最後一個Jet引擎版本,它支援了下列的能力:

  1. Unicode字元儲存支援,使用與Windows NT相同,並且也在Windows 95上版本實作的排序方法。
  2. 變更資料型別,讓它更貼近SQL Server,並支援新的decimal資料型別。
  3. Memo欄位可以設定索引。
  4. 可壓縮資料型別。
  5. 強化SQL讓Jet更符合ANSI SQL-92規範。
  6. 更好的安全性,檢視表支援,程序支援。
  7. 交易的完成與終止(認可或撤回)。
  8. 強化的表格建立與修改。
  9. 參考完整性支援。
  10. 連線控制。
  11. 使用者清單,允許管理員能決定誰可連到資料庫。
  12. 記錄層級鎖定(前一版本只支援頁鎖定)。
  13. Microsoft SQL Server的雙邊複製能力。

支援的資料庫[编辑]

Microsoft Access[编辑]

Access是Jet最主要的支援對象之一,因此對Access的支援是最充足的,依版本的不同,由MSRD2x40.DLL(Jet 2.x)、MSRD3x40.DLL (Jet 3.x)與MSJET40.DLL支援:

Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=C:\mydatabase.mdb;

Microsoft Excel[编辑]

Excel則是在Jet 2.x開始支援的資料儲存體,雖然可以使用SELECT,INSERT,UPDATE三種查詢,但無法使用DELETE刪除資料,而且其SQL指令的使用限制也很多[2]

Excel的驅動程式由MSEXCL40.DLL提供,目前可支援:

  • Excel 3.0(Office 3.0)
  • Excel 4.0(Office 4.0)
  • Excel 5.0(Office 4.3)
  • Excel 8.0(Office 97-2000)
Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=C:\MyExcel.xls;
Extended Properties="Excel 8.0;HDR=Yes;IMEX=1";

Exchange[编辑]

Microsoft Jet支援Exchange 4.0資料庫,但後續版本即不再支援,目前它可存取Outlook 9.0 (Outlook 2000)的資料檔,由MSEXCH40.DLL支援。

Provider=Microsoft.JET.OLEDB.4.0;Exchange 4.0;
MAPILEVEL=Outlook Address Book\;
PROFILE=Outlook;
TABLETYPE=1;
DATABASE=c:\temp

HTML Table[编辑]

在網頁中的HTML表格可以利用Jet來存取,分為HTML import和HTML export兩個部份,分別處理HTML的SELECT(輸入)與INSERT(輸出)。

Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=http://www.acme.com/tb.html;
Extended Properties="HTML Import;HDR=YES;IMEX=1";

Paradox[编辑]

Jet可以連接與存取Paradox資料庫,由MSPBDE40.DLL支援,目前可用的版本有:

  • Paradox 3.x
  • Paradox 4.x
  • Paradox 5.x
  • Paradox 7.x
Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=C:\Program Files\Microsoft Office\Office;
Extended Properties=Paradox 5.x

dBase[编辑]

dBase檔案的支援由MSXBDE40.DLL支援,目前可用的版本有:

  • dBase III
  • dBase IV
  • dBase 5.0
Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=c:\myDB;
Extended Properties=dBASE IV;

文字檔案[编辑]

文字檔案 (text file)的支援是Jet較為特殊的資料來源類型之一,它由MSTEXT40.DLL支援,它同時也是HTML Import與HTML Export的基礎。

Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=c:\txtFilesFolder\;
Extended Properties="text;HDR=Yes;FMT=Delimited";

Lotus 1-2-3[编辑]

Lotus 1-2-3的試算表可由Jet存取,可支援Lotus的WJ2, WJ3, WK1, WK3與WK4等檔案格式,由MSLTUS40.DLL提供支援。

Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=C:\temp\FILE0014.WK4;
Extended Properties=Lotus WK4;
Persist Security Info=False

對於Microsoft Office 2007的支援[编辑]

由於Microsoft Office 2007對其旗下Access與Excel的主要檔案格式進行修改,並且重新命名為.accdb(Access 2007資料庫檔案)與.xlsx(Excel 2007檔案),因此未被Microsoft Jet引擎所支援,不過微軟也很快的提出了Microsoft Office 2007 Desktop Drivers: Data Connectivity Components來支援,其連接字串中的資料提供者改為Microsoft.ACE.OLEDB.12.0

Access 2007的連線字串為[3]

Provider=Microsoft.ACE.OLEDB.12.0;
Data Source=C:\myFolder\myAccess2007file.accdb;
Persist Security Info=False;

Excel 2007的連線字串為[3]

Provider=Microsoft.ACE.OLEDB.12.0;
Data Source=c:\myFolder\myExcel2007file.xlsx;
Extended Properties="Excel 12.0 Xml;HDR=YES";

不過它和Microsoft Jet一樣,都無法支援x64平台。

參考資料[编辑]

  1. ^ 1.0 1.1 1.2 Dan Haught, Jim Ferguson. Microsoft Jet Database Engine Programmer's Guide 2/e. Microsoft Professional Editions. Microsoft Press. 1997. ISBN 1572313420. 
  2. ^ HOW TO:使用ADO.NET擷取與修改利用Visual Basic .NET之Excel活頁簿中的記錄
  3. ^ 3.0 3.1 ConnectionStrings.com