跳转到内容

Microsoft Access

本页使用了标题或全文手工转换
维基百科,自由的百科全书
(重定向自.mdb
Microsoft Access
Microsoft Access 2019圖示
開發者微軟
首次发布1992年11月,​32年前​(1992-11
当前版本2021(2021年10月5日,​3年前​(2021-10-05
编程语言C++
操作系统Microsoft Windows
类型關聯式資料庫管理系統
许可协议專有EULA
网站https://products.office.com/access

Microsoft Office Access(前名Microsoft Access)是由微軟發佈的關聯式資料庫管理系統。它結合了Microsoft Jet Database Engine圖形用戶界面兩項特點,是Microsoft Office的系統程式之一。

Access能夠存取Access/Jet、Microsoft SQL ServerOracle數據庫,或者任何ODBC相容資料庫內的資料。雖然它支持部分物件導向技術,但是未能成為一種完整的物件導向開發工具。

其實Access也是微軟公司另一個通訊程式的名字,想與ProComm以及其他類似程式來競爭。可是事後微軟證實這是個失敗計劃,並且將它中止。數年後他們把名字重新命名於此數據庫軟體。

歷史

[编辑]
年份 版本 版本代號 作業系統需求 對應的Office版本
1992年 Access 1.1 1 Windows 3.0
1993年 Access 2.0 2.0 Windows 3.1x Office 4.3 Pro
1995年 Access for Windows 95 7.0 Windows 95 Office 95 Professional
1997年 Access 97 8.0 Windows 9x、NT 3.51/4.0 Office 97 Professional、Developer
1999年 Access 2000 9.0 Windows 9x、NT 4.0、2000 Office 2000 Professional、Premium及Developer
2001年 Access 2002 10 Windows 98以上 Office XP Professional及Developer
2003年 Access 2003 11 Windows 2000以上 Office 2003 Professional及Professional Enterprise
2007年 Microsoft Office Access 2007 12 Windows XP SP2 Office 2007 Professional、Professional Plus、Ultimate及Enterprise
2010年 Microsoft Office Access 2010 14 Windows XP SP3、Vista SP1、Windows 7 Office 2010 Professional、Professional Academic及Professional Plus
2012年 Microsoft Office Access 2013 15 Windows Server 2008 R2Windows 7 Office 2013 Professional及Professional Plus
2015年 Microsoft Office Access 2016 16 Windows 7 Office 2016 Professional及Professional Plus
2018年 Microsoft Office Access 2019 Windows 10 Office 2019 Professional及Professional Plus
2021年 Microsoft Office Access 2021 Windows 10Windows 11 Office 2021 Professional及Professional Plus

Microsoft Access 1.0發佈於1992年11月,當時該軟體以7張1.44 MB磁片形式發售。

為了配合Word的版本號碼,Access版本號自Office 95開始與Word同步,版本號配合Word 7訂為7.0。

Access 2007起資料庫改以新檔案格式.accdb儲存。由於與舊Access版本不相容,若需在較舊的Access版本裡讀取,需要先轉存回.mdb

Access 2013起已不再支援dBase資料庫,無法匯入.dbase的資料庫檔案。

由於Office 2024不再提供Professional版本,故Access不再於零售賣斷的Microsoft Office版本中出現;但Microsoft 365訂閱版本中仍設有Access。

用途

[编辑]

Microsoft Access在很多地方得到廣泛使用,例如小型企業,大公司的部門。喜愛編程的開發人員亦利用它來製作處理數據的桌面系統。它也常被用來開發簡單的WEB應用程式。

它的使用方便程度和強大的設計工具為初級程式員提供許多功能。不過,方便性的宣傳,常令人誤解。在過於樂觀的誤導下,讓許多沒有程式設計背景的辦公室從業人員應用此軟體,並以為能夠創造可用的系統,但此工具本身的局限性,常常使這些使用者失敗。

一些專業的應用程式開發人員使用Access內附的快速應用開發功能,特別是給街道上的推銷員製作一個初型或獨立應用程式的工具。可是如果是透过網路存取數據的話,Access的可擴放性並不高.因此當程式被較多使用者使用時,他們的選擇多會是傾向於一些客戶端-伺服器為本的方案,例如OracleIBM DB2Microsoft SQL ServerWindows SharePoint ServicesPostgreSQLMySQLAlpha FiveMaxDB,或者Filemaker。無論如何,不少Access的功能(表單,報告,序列和VB代碼)可以用作其他數據庫的後期應用,包括JET(檔案為主的數據庫引擎,Access預設使用)、Microsoft SQL ServerOracle和任何其他跟ODBC相容的產品。這種方法允許開發者把一個成熟的應用的數據移動到一台更大功率的伺服器而不會在適當的位置犧牲發展。

SQL

[编辑]

Access查询中使用的默认使用“Microsoft Jet SQL”,而ADO中使用的SQL语法是“ANSI SQL”。这两种语法存在轻微的差别(中间还包含某些特殊函数和功能)并非完全兼容。其中通配符就不一样:对于多个字符,前者是 * 而后者是% ; 对于单个字符,前者是 ? 而后者是 _ 。 Jet SQL基本遵从了SQL ANSI-89 Level 1 compliant。对于Access的字段类型为True/False,在SQL语句中可用0对应False,-1对应True。不能用1对应True。

也可以将ACCESS数据库查询的语法设置为兼容ANSI SQL(在ACCESS选项那里设置),但是这样做的话,编写SQL语句就要遵循ANSI SQL语法规则了。对于之前已经使用过的ACCESS数据库不建议这样做,因为很可能会导致原有编写的SQL查询失效,进而造成诸多不便。

Access使用的Jet SQL引擎,每次只能执行一条SQL语句。如果成批执行多条SQL语句,需要使用Visual Basic for Applications编程。在Access的VBA中执行SQL语句,有三种方法。

  • DoCmd.RunSQL:基于Access的对象模型,使用Microsoft Jet SQL,在SQL语句中可以使用VBA函数。需要在调用前设置DoCmd.SetWarnings False关闭提示或确认对话框。执行时在Access状态栏显示进度条,可通过Esc键中止执行。不能获取SQL语句影响的记录行数。不能将多个SQL语句的执行放在同一事务中。
  • CurrentDB.Execute:基于DAO对象模型,使用Microsoft Jet SQL,在SQL语句中可以使用VBA函数。没有提示或确认对话框的显示。执行时没有在Access状态栏显示进度条,不可以通过Esc键中止执行。能获取SQL语句影响的记录行数。可以将多个SQL语句的执行放在同一事务中。
  • CurrentProject.Connection.Execute:基于ADO对象模型,连接到不同数据库使用不同的SQL语法。对Access使用ISO SQL标准语法并可以使用VBA函数。没有提示或确认对话框的显示。执行时没有在Access状态栏显示进度条,不可以通过Esc键中止执行。能获取SQL语句影响的记录行数。可以将多个SQL语句的执行放在同一事务中。

例如:

 
Dim strSQL As String
strSQL = "SELECT * INTO [excel 8.0;database=d:\gz.xls].sheet1 FROM table1 WHERE table1.city = 'gz' " 
 :REM 执行该函数进行SQL查询 
CurrentProject.Connection.Execute strSQL

编程模型

[编辑]

Access软件自身提供了一套COM对象体系,可供其它软件(如Excel)使用VBA或者C#C++等编程语言调用Access的功能。

  • Application:Access应用程序环境
  • DBEngine:数据库管理系统
  • Debug:立即窗口对象,可用Print输出文本
  • Forms:包含所有打开的窗口
  • Reports:包含所有打开的报表
  • Screen:屏幕
  • DoCmd

延伸閱讀

[编辑]
  • "Microsoft Office Access 2003 Inside Out" by John L. Viescas
  • "Database Design for Mere Mortals" by Michael J. Hernandez
  • "Access Database Design & Programming" by Steven Roman
  • "Access 2002 Developer's Handbook™ Set By Paul Litwin; Ken Getz; Mike Gunderloy
  • "Succeeding in Business with Microsoft Office Access 2003: A Problem-Solving Approach" by Karin Bast, Leon Cygman, Gerard Flynn, Rebekah Tidwell
  • "Access 2003 VBA Programmer's Reference" by Patricia Cardoza, Teresa Hennig, Graham Seach, Armen Stein
  • "SQL Access to SQL Server" Published by Apress - Susan Sales Harkins and Martin WP Reid
  • "Mastering Microsoft Office Access 2003" Published by Sams - Alison Balter

參見

[编辑]

外部連結

[编辑]

本條目部分或全部内容出自以GFDL授權發佈的《自由線上電腦詞典》(FOLDOC)。