设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 1196|回复: 2
打印 上一主题 下一主题

[Access本身] Microsoft数据引擎 MSDE

[复制链接]

点击这里给我发消息

跳转到指定楼层
1#
发表于 2004-1-29 00:54:00 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
概述
创建应用程序的开发人员面临着这样一个选择:在众多的数据库选项中,应该选择哪一种技术?在选择一种数据库技术之前,开发人员需要考虑很多因素。比如,该应用程序需要支持多少个用户?所有的用户是否会同时访问数据库系统?该应用程序的开发涉及到哪些费用?如果该应用程序的需求随着时间的推移而发生变化,该技术是否允许对该数据库的功能和规模进行扩充?
直到最近,Microsoft推出了两种数据库管理方案:Microsoft Jet (即Microsoft Access 数据引擎,该引擎随同Access 和Microsoft Visual Studio发布) 和 Microsoft SQL Server。由于每一种技术方案都有自身的优势,同时又存在某些局限性,因此,以前如果要求开发人员选择这样一种数据库技术:使它既满足从桌面到数据中心环境下运行,而数据库应用程序又适应长期和短期需要,一般而言是很困难的。由于基于Jet的解决方案具有易于使用和开发成本低的优点,因此,对于桌面或者共享的应用程序而言,它是一种很不错的选择。然而,开发人员发现:随着应用系统规模的扩大,在他们将Jet应用程序移植到SQL Server的平台之前,需要对程序代码进行大量的修改。值得开发人员高兴的是:随着一个与SQL Server 兼容的数据引擎—Microsoft 数据引擎(MSDE)的发布,开发人员可以选用一种新的方式来创建基于桌面和共享环境的数据库应用程序。利用MSDE,开发人员可以创建自由分布的桌面和共享的数据库解决方案。当需要对系统的规模进行扩充时,采用这种解决方案的数据库应用程序可以很容易地移植到SQL Server中。
数据引擎涉及哪些技术
从本质上讲,一个处于运行状态的“数据引擎”就是一个核心进程。一个数据库管理系统,比如Access 或者 SQL Server,将利用这个核心进程来存储和管理数据库中的数据。从这种意义上讲,我们通常可以把一个数据引擎看作是一个没有相应的图形管理工具的数据库管理系统。数据引擎主要有两种作用:一是用来存储数据,二是用来处理其它对象对存储的信息所提交的请求。我们通常把用来检索或者更新数据的请求称作数据库查询。
通常,数据引擎与自定义数据库应用程序一起对客户机应用程序提交的数据库请求进行响应。自定义数据库应用程序是用某种开发工具,比如Microsoft Visual Studio创建的。在这种情况下,由于自定义的数据库应用程序已经包含了内置的工具对底层的数据库进行管理,因此,在数据引擎中,就没有必要包含图形工具来对数据库进行管理了。此外,由于数据引擎具有容易分布的特点,开发人员可以将相应的数据引擎包含到自定义应用程序中,在应用程序的安装过程中,用户可以通过选取该引擎组件而将其安装到系统中。
Microsoft数据引擎
Microsoft 数据引擎(MSDE)与SQL Server完全兼容,在以Visual Studio 6.0 或者Access 2000为开发工具所创建的桌面和共享的数据库解决方案中,该引擎可以用来对数据库进行处理。对于Visual Studio 6.0 或者 Access 2000开发人员来说, 他们可以在不单独对MSDE进行注册的情况下发布使用MSDE创建的数据库应用程序。MSDE用到了SQL Server提供的一些技术,并且与SQL Server 7.0完全兼容。在Access 2000中,MSDE是代替Jet(Access 2000数据库使用的缺省引擎)的理想选择。此外,对于Visual Studio 6.0开发人员而言,如果他们想创建自定义的数据库应用程序,并且希望在这些自定义的应用程序中使用与SQL兼容的的数据库,那么,他们可以通过采用MSDE作为数据引擎的方式来达到这一目的。MSDE与SQL的兼容性意味着:开发人员可以对现有的以MSDE作为数据引擎、桌面和共享的数据库应用程序代码不作任何修改,就可以将其移植到SQL Server中。
MSDE以提供某种服务的方式在后台运行。在此,服务指的是以后台进程运行的应用程序。服务与其它的应用程序的运行方式有所不同。比如,只要用户通过从“开始”菜单选取“启动”选项,对应的应用程序就可以投入运行。但对于服务而言,如MSDE,情况就不是这样。它们的启动和关闭通常是由操作系统来完成的。以MSDE作为数据引擎的桌面和共享的数据库应用程序通常具有以下限制:在数据库应用程序存活期间,MSDE服务应该处于运行状态。一般而言,使用服务的对象是其它应用程序,而不是终端用户。一般情况下,服务在后台运行,当它接收到客户机应用程序向它提交的处理请求时,它就转去执行相应的请求。对于MSDE来说,这些请求是一些将要对数据库执行的操作。由于使用服务的对象是客户机应用程序,而不是终端用户,因此服务不需要有用户界面。在Access 2000中创建的一个工程或者一个Visual Basic应用程序可以直接与某个服务进行交互。对于MSDE而言,这些客户机应用程序充当了用户界面。
MSDE的特性:
* 完全与Microsoft SQL Server 7.0 以及以前的版本相兼容。
* 对于Visual Studio 6.0 或者 Microsoft Office 2000 开发人员而言,他们可以将基于MSDE的数据库应用程序免费发布给最终用户。
* 可以在Windows 95, Windows 98, Windows NT, 以及Windows 2000 (Intel 和 Alpha)平台上运行。
* 具有客户机/服务器的体系结构(MSDE在数据库服务器,而不是在客户机
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
3#
发表于 2006-1-12 21:15:00 | 只看该作者
呵呵,非常感谢,

刚翻到

听说MSDE能够较好的支持较多的并发用户读写数据库

那么,很想知道:

如何用MSDE引擎来连接后台MDB?

点击这里给我发消息

2#
 楼主| 发表于 2004-1-29 00:54:00 | 只看该作者
MSDE小结
如果开发人员希望创建桌面或者共享的数据库应用程序,并且计划在将来对这些数据库应用程序的功能和规模进行扩充,那么,选用MSDE作为数据引擎将具有以下优点:从近期来看,能够降低系统的开发费用,从远期来看,又提供了最为方便的方式,以对当前创建的数据库应用程序进行移植。当你所在组织的规模扩大后对数据库系统的功能和性能提出新的需求时,你可以在不修改现有数据库应用程序中的任何代码的情况下,将它完全移植到基于SQL Server的平台上运行。此外,由于MSDE与SQL 完全兼容,开发人员可以使用同样的数据访问语言在规模相对较小的MSDE数据库系统和规模较大的SQL Server数据库系统之间实现无缝转换。
在哪些情况下选用Jet
对于一些特殊的数据库系统而言,以Jet 4.0作为引擎也是一个很不错的选择。在这一节中,我们将讨论在哪些情况下应该选用Jet作为数据库引擎。
分布性
在采用Jet作为引擎的数据库系统中,由于数据库包含在一个独立的文件中,因此备份和发布数据库的工作就变得非常容易。虽然在数据库系统的运行过程中,其它文件会通过诸如Visual Basic 或者 Microsoft Access这种类型的应用程序来访问Jet数据库文件,但由于开发人员对这些文件之间的相关性进行了良好的定义,因此,访问数据库文件的操作不会占用系统大量的存储空间或者使用大量的处理器资源。与Jet 数据库相比,MSDE数据库比较难于发布和安装。因此,如果希望简化数据库的发布和安装的过程,选用Jet作为数据库的引擎是一个很不错的选择。
开发费用
开发人员可以将基于Jet 4.0的数据库随同用下面的工具开发的数据库应用程序一起发行:
* Microsoft Office 2000
* Microsoft Access 2000
* Visual Studio 6.0 任何版本中的相关工具组件(在文章的前面部分列出了这些组件)
如果开发费用是创建数据库应用程序时要考虑的重要因素,选用Jet作为数据引擎是一个很不错的选择。
可伸缩性
MSDE 和 Jet数据库都可以在桌面和共享的数据库应用程序中运行。对于有些数据库应用程序而言,它们所处理的数据量可能永远也不会超过2GB,并且所支持的用户数也不会超过20个。如果你手头有一个Jet数据库应用程序,即使随着系统规模的增长,它所处理的数据量也不会很大,并且需要支持的用户数也不够多,那么,将Jet作为现有数据库的引擎仍不失为一个好的选择.
对系统资源的需求
由于Jet数据库经过了压缩处理,因此在那些资源有限的平台上,选用Jet作为数据库的引擎是合适的。在这篇文章所讨论的三种数据引擎中,以Jet作为引擎的数据库占用的存储空间和消耗的系统内存最少。如果使用的机器的磁盘空间或者系统内存非常有限,那么选用Jet作为引擎将是非常明智的选择。
与以前版本的兼容性
Jet 4.0对那些基于以前的版本的数据库提供了最大的兼容性。你可以将现有的多个不同版本Jet数据库应用程序放在同一个系统中运行。只要你不将SQL Server 或者 MSDE加入到数据库系统中,那么你现有的系统仍将是一个基于Jet/Access解决方案的数据库系统。如果在你现有的一个Jet数据库应用程序中调用了在Jet以前版本中定义的一个函数,或者调用了这样一个函数:你需要进行大量的处理工作才能将该函数转化到与SQL兼容的数据库中运行,那么,采用Jet作为数据库的引擎将比采用MSDE 或者 SQL Server 7.0具有更大的优越性。
JET小结
对于那些在当前要求处理的数据量不大、需要支持的并发用户数也不多,并且在将来也不会有很大增长的的数据库管理系统而言,基于Jet的数据库系统具有开发费用低、维护方便的优点,并且与以前版本的Jet数据库系统具有最大的兼容性。
在哪些情况下应选择
SQL Server
看到这一节的标题,你可能想问:为什么不以MSDE或者Jet作为引擎来开发所有的数据库系统呢?对这个问题的答案是:基于Jet 甚至是MSDE的数据库系统在有些情况下已经不能满足实际的需要了。在下面,我们对这些情况进行了说明。
数据库的容量
基于MSDE的数据库最多能存储2GB大小的数据。基于Jet的数据库中的每一个文件能够存储的数据也无法超过2GB。由于Jet数据库文件可以通过相互链接的方式来增大存储能力,因此最终存储的数据量只受到磁盘空间大小的限制。但是,管理多个数据文件将是一项非常困难的工作。因此,如果你现有的数据库的大小超过了2GB,或者是在将来会突破这一限制,那么选用SQL Server作为数据库系统的引擎将是最佳的选择。
支持的并发用户数
当数据库系统需要支持的并发用户数不超过5个时,采用MSDE作为数据库的引擎将会获得最优的系统性能。Microsoft极力推荐:为了使MSDE数据库系统表现出优越的性能,系统所支持的并发用户数不要超过5个。
从技术和授权的角度上来讲,基于Jet的数据库系统支持的用户数可以达到255个,但在实际中,系统支持的用户数最好不要超过20个。这样的原因是:Jet 数据库系统采用基于文件的方式来存储数据,因此,随着连接的用户数量的增加,需要对文件执行读写操作的用户数也将不断增加,从而使系统的性能变差。
由于SQL Server 可以支持成千上万个并发用户,因此可以在最大程度上满足企业级数据库系统的性能
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2025-1-25 18:22 , Processed in 0.103531 second(s), 27 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表