Microsoft Access
Microsoft Office Access(前名Microsoft Access)是由微軟發佈的關聯式資料庫管理系統。它結合了Microsoft Jet Database Engine和圖形用戶界面兩項特點,是Microsoft Office的系統程式之一。
開發者 | 微軟 |
---|---|
初始版本 | 1992年11月 |
穩定版本 | 2019 (16.0.12430.20264) (2020年2月11日 ) |
编程语言 | C# |
操作系统 | Microsoft Windows |
类型 | 關聯式資料庫管理系統 |
许可协议 | 專有EULA |
网站 | https://products.office.com/access |
Access能夠存取Access/Jet、Microsoft SQL Server、Oracle數據庫,或者任何ODBC相容資料庫內的資料。熟練的軟體設計師和資料分析師利用它來開發應用軟體,而一些不熟練的程式員和非程式員的進階用戶則能使用它來開發簡單的應用軟體。雖然它支援部分物件導向技術,但是未能成為一種完整的物件導向開發工具。
其實Access也是微軟公司另一個通訊程式的名字,想與ProComm以及其他類似程式來競爭。可是事後微軟證實這是個失敗計劃,並且將它中止。數年後他們把名字重新命名於此數據庫軟體。
目前最新的Access版本是Microsoft Access 2019 for Windows。
歷史
年份 | 版本 | 版本 代號 | 支援系統 | Office套件版本 |
---|---|---|---|---|
1992年 | Access 1.1 | Windows 3.0 | ||
1993年 | Access 2.0 | Windows 3.1x | Office 4.3 Pro | |
1995年 | Access for Windows 95 | Windows 95 | Office 95 Professional | |
1997年 | Access 97 | Windows 9x,NT 3.51/4.0 | Office 97 Professional及Developer | |
1999年 | Access 2000 | Windows 9x,NT 4.0,2000 | Office 2000 Professional,Premium及Developer | |
2001年 | Access 2002 | Windows 98,Me,2000,XP | Office XP Professional及Developer | |
2003年 | Access 2003 | Windows 2000,XP,Vista | Office 2003 Professional及Professional Enterprise | |
2007年 | Microsoft Office Access 2007 | Windows XP SP2,Vista | Office 2007 Professional,Professional Plus,Ultimate及Enterprise | |
2010年 | Microsoft Office Access 2010 | Windows XP SP3,Vista SP1,Windows 7 | Office 2010 Professional,Professional Academic,及Professional Plus | |
2012年 | Microsoft Office Access 2013 | Windows Server 2012,Windows Server 2008 R2,Windows 7,Windows 8 | Office 2013 Professional及Professional Plus | |
2015年 | Microsoft Office Access 2016 | Windows 7,Windows 8,Windows 8.1,Windows 10 | Office 2016 Professional及Professional Plus | |
2018年 | Microsoft Office Access 2019 | Windows 10 | Windows Server 2019 |
Microsoft Access 1.0版本在1992年11月發佈。
微軟配置它於系統Windows 3.0內,並以最小8MB硬碟空間的系統要求,當時該軟體以7張1.44MB軟碟儲存發售。
此軟體能夠有效地處理大量記錄。但是測試顯示在某些情況下,會導致數據損毀。之後,該軟體歷經改良至今已成為微軟OFFICE商用軟體的主要系統之一。
Access 2007推出 .accdb的副檔名,如果電腦只有Access 2003(.mdb)的版本,無法像 Word,Excel 相容(無法開啟),必須轉換成 .mdb檔案。
Access 2013已經無法匯入 .dbase(DataBase)的資料庫檔案。
用途
Microsoft Access在很多地方得到廣泛使用,例如小型企業,大公司的部門。喜愛編程的開發人員亦利用它來製作處理數據的桌面系統。它也常被用來開發簡單的WEB應用程式。
它的使用方便程度和強大的設計工具為初級程式員提供許多功能。不過,方便性的宣傳,常令人誤解。在過於樂觀的誤導下,讓許多沒有程式設計背景的辦公室從業人員應用此軟體,並以為能夠創造可用的系統,但此工具本身的局限性,常常使這些使用者失敗。
一些專業的應用程式開發人員使用Access內附的快速應用開發功能,特別是給街道上的推銷員製作一個初型或獨立應用程式的工具。可是如果是透过網路存取數據的話,Access的可擴放性並不高.因此當程式被較多使用者使用時,他們的選擇多會是傾向於一些客戶端-伺服器為本的方案,例如Oracle、IBM DB2、Microsoft SQL Server、Windows SharePoint Services、PostgreSQL、MySQL、Alpha Five、MaxDB,或者Filemaker。無論如何,不少Access的功能(表單,報告,序列和VB代碼)可以用作其他數據庫的後期應用,包括JET(檔案為主的數據庫引擎,Access預設使用)、Microsoft SQL Server、Oracle和任何其他跟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
參見
- Microsoft SQL Server
- Microsoft Office
- Microsoft
- List of relational database management systems
- Xbase
- Comparison of relational database management systems
- Data Normalization Basics 页面存档备份,存于
- Visual Basic
外部連結
- Why Use Microsoft Access
- Microsoft Access Articles and Tutorials 页面存档备份,存于
- Utter Access Forums 页面存档备份,存于
- Access知識庫/程式設計俱樂部 页面存档备份,存于
- A FAQ site about Microsoft Access 页面存档备份,存于
- Microsoft Access Linklist 页面存档备份,存于
- Microsoft Access Newsgroups
- Microsoft Access for Beginners
- Articles on Microsoft Access 页面存档备份,存于
- Blog about Microsoft Access Tips and Tricks 页面存档备份,存于
- History of JET database 页面存档备份,存于
- Additional info on history of Access
- Access Opener utility manages multiple versions 页面存档备份,存于
- Access术语表 页面存档备份,存于