首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Microsoft.Jet.OleDb与Microsoft.Ace.OleDb的区别

Microsoft.Jet.OleDb与Microsoft.Ace.OleDb的区别
EN

Stack Overflow用户
提问于 2013-01-18 23:07:02
回答 2查看 74.5K关注 0票数 54

自从我用Classic ASP和Microsoft Access做一些编程,我们使用"Microsoft.Jet.Oledb“驱动程序访问和显示数据以来,已经有很长一段时间了。

我被要求使用"Microsoft.Ace.Oledb“来访问MS Excel数据。我发现这是"Microsoft Access 2010 Engine Redistributable“下载的一部分。

我想知道"Microsoft.Jet.OleDb“是否取代了"Microsoft.Ace.Oledb”驱动,本质上是相同的,还是完全不同的东西?

另外,当你购买MS Access 2010时,你通常会得到"Microsoft.Ace.Oledb“驱动程序吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-01-18 23:14:39

这主要是一个历史问题,实际上ACE已经取代了JET:

Wikipedia answers your question的详细信息。

最相关的部分是:

从2007版开始,Access包含特定于办公室的Jet版本,最初称为Office Access Connectivity Engine (ACE),但现在称为Access数据库引擎。此引擎与早期版本的Jet引擎完全向后兼容,因此它从早期Access版本读取和写入(.mdb)文件。它引入了一种新的默认文件格式(.accdb),它为Access带来了一些改进,包括复杂的数据类型,如多值字段、附件数据类型和备注字段中的历史跟踪。它还带来了安全性和加密改进,并支持与Microsoft Windows SharePoint Services3.0和Microsoft Office Outlook2007集成

此外,ACE提供64位驱动程序,因此可以在64位机器上使用,而JET不能。

该驱动程序不是视窗操作系统的一部分,而是作为可再发行的。11以前,Jet数据库引擎仅为32位,并且不能在64位版本的视窗下本地运行。

关于你问题的第二部分,我最近安装了Office 2010,我必须单独下载ACE组件。我从link Microsoft Access Database Engine 2010 Redistributable上拿到的。这可能是因为我在64位Windows下安装了32位版本的Office;在任何情况下,都可以很容易地从Microsoft获得所需的文件。

票数 76
EN

Stack Overflow用户

发布于 2015-11-13 06:18:48

这些驱动程序在用于基本操作时本质上是相同的,并且与更复杂的东西(联合、嵌套查询等)显示出显著的差异。

根据个人经验,ACE不能提供完全向后兼容的结果。它可以打开和读/写以前的.mdb格式,但是数据类型对完全相同的查询进行了转换。

例如,在文本字段上使用UNION时,JET用于返回文本(255)结果,ACE返回MEMO ?!

这可能会在与BI或Crystal Reports等报告工具结合使用时产生很多麻烦。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14401729

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档