Dao与Jet数据库引擎

DAO可以访问本地数据库和远程数据库。这里指的本地和远程并不是地理位置上的概念,它们是两个逻辑概念。本地数据库可以在本地计算机(物理)上,也可以不在本地计算机上,而远程计算机也并不局限于远程计算机(物理)上。
本地数据库是通过文件系统访问的数据库,它可以放在本地计算机上,也可以放在网络上,它由应用程序直接操作。而远程数据库只能由DBMS操作,应用程序对它的访问通过DBMS来完成,这样就产生了Client/Server体系结构,应用程序是Client端,DBMS是Server端。
Microsoft Jet是Microsoft Access和Visual Basic使用的一种数据库引擎。在DAO3.1版本以前,DAO被定义为“Microsoft Jet引擎的编程接口”,也就是说,DAO和Jet在历史上几乎是同义词。DAO访问数据库都要通过Microsoft Jet数据库引擎来完成。当然,这两个概念在内涵上是不一样的,Jet不能被直接使用,只有通过DAO或Access才能直接使用Jet.
但是,DAO3.1之后增加了一项重要的功能,这就是ODBCDirect访问。ODBCDirect使得DAO可以跳过Jet引擎,直接访问ODBC数据源。正是由于有了这项功能,DAO不再绑定在Jet上了,DAO与Jet仍有千丝万缕的联系。一般来说,如果应用程序使用的是本地数据库,那么DAO一般都通过Jet来访问数据库,反之,如果使用的是远程数据库,那么DAO通过ODBCDirect来访问数据库。
Jet是通过SQL来驱动的,但是这种SQL可能和通常的实现不太一样。这种情况下可能会带来好处,也有可能会带来坏处。当使用DAO访问数据库时就必须考虑这种差别。因为Jet的SQL的运行和一些标准的SQL运行性能差异很大。考虑下面这个SQL语句:
SELECT * FROM Student,Teacher
WHERE Student.Course_No=Teacher.Course_No
在SQL SERVER中执行这个SQL语句时,SQLSERVER会在内部自动把Student表和Teacher表使用的最优化方式连接起来,即用Student表的Course_No域的值来索引Teacher表,因此,每读取一条Student记录,只需读一条Teacher记录,整个语句的执行共需读取2*COUNT(Student)个记录。
但是,同样是这个语句,通过DAO和Jet来执行时,Jet会把两个表进行笛卡尔连接,然后再滤掉一些不合格条件的记录。这样一来,每读一条Student记录,都必须读取所有的Teacher记录,即COUNT(Teacher)条Teacher记录,整个语句的执行共需读取COUNT(Student)*COUNT(Teacher)条记录。如果这两个表的数据庞大的话,这个语句的执行速度将令人不可忍受。

时间: 2025-01-19 03:12:22

Dao与Jet数据库引擎的相关文章

为进行 ODBC 访问配置 Microsoft Jet 数据库引擎

odbc|访问|数据|数据库 为进行 ODBC 访问配置 Microsoft Jet 数据库引擎    以下各节描述 Microsoft Jet 数据库引擎用于连接 ODBC 数据库的 Microsoft Windows 注册表设置.   连接 ODBC 数据库的 Microsoft Jet 的初始化设置 \HKEY_LOCAL_MACHINE oftware\Microsoft\Jet\4.0\Engines\ODBC 文件夹包含 Microsoft Jet 数据库引擎的初始化设置. 注释  

vb相对链接-Microsoft Jet 数据库引擎找不到输入表或查询‘Student’。

问题描述 Microsoft Jet 数据库引擎找不到输入表或查询'Student'. Student是我建立的Access数据库名)这是怎么弄好该>? 解决方案 请详细说明你的操作过程,最好有截图.

C#OleDb读取dbf,文件名超过8位就报错:Microsoft Jet 数据库引擎找不到对象'123456789' 请确定对象是否存在

问题描述 stringconnStr="Provider=Microsoft.Jet.OLEDB.4.0;DataSource=C:\;ExtendedProperties=dBASEIV;UserID=Admin;Password=;";OleDbConnectionconn=newOleDbConnection(connStr);conn.Open();stringcmdText="select*from123456789";//123456789.dbf文件O

在此给大神跪了,在做一个导入Excel的模块,报的错Microsoft Jet 数据库引擎找不到对象'Sheet1$'。

问题描述 后代代码如下:privatevoidbutton3_Click(objectsender,EventArgse){string_strExcelFileName=@"D:example.xls";DataTabledtExcel=ExcelToDataTable(_strExcelFileName,"Sheet1");try{foreach(DataRowdrindtExcel.Rows){stringsql=string.Format("Ins

Microsoft Jet 数据库引擎打不开文件 ……它已经被别的用户以独占方式打开,或没有查看数据的权限

问题描述 语言C#,代码对一个文件的多个sheet进行分次读取,读到某个sheet(不确定)的时候就可能报异常,非必现,但是CI上发生概率比较大,程序只读取不写入.出错程序退出后,任务管理器中没有发现excel进程.excel文件为xls文件请大虾们帮忙看下可能原因有哪些,因为不是必现,也不能调试,找不到原因,代码大概如下,之前没有adp.dispose();后面加上还是报错:stringstrConn="Provider=Microsoft.Jet.OLEDB.4.0;DataSource=&

Jet数据引擎和MSDE的比较分析

1 Jet数据引擎和MSDE 1.1 Jet数据引擎 Microsoft Jet 数据引擎是Microsoft Access 数据库系统的一部分,用于在用户和系统数据库中检索和存储数据.Microsoft Jet 数据引擎可以作为一个数据管理器,以它为基础可以创建如 Microsoft Access 这样的数据库系统. 在Access 97中,数据引擎采用的是Jet 3.51:在Access 2000中,默认的数据引擎采用的是Jet 4.0. 与以前版本的Jet相比,Jet4.0在以下几个方面进

启动服务器SQL Server 2005数据库引擎的方法

SQL2005数据库引擎没有启动的解决方法,SQL2005已经不再像SQL2000那样,单独有一个服务器管理... 数据库引擎没有启动. 有两种启动方式: (1)开始->程序->Microsoft SQL Server 2005->SQL Server 2005外围应用配置器,在打开的界面单击"服务的连接的外围应用配置器",在打开的界面中找到Database Engine,单击"服务",在右侧查看是否已启动,如果没有启动可单击"启动&qu

MySQL数据库引擎快速指导

如果你是个赛车手,并且按一下按钮就能够立即更换引擎而不需要把车开到车库里去换,那会是什么感觉呢?MySQL数据库为开发人员所做的就好像是按按钮换引擎:它让你选择数据库引擎,并给你一条简单的途径来切换它. MySQL的自带引擎肯定是够用了,但是在有些情况下,其他的引擎可能要比手头所用更适合完成任务.如果愿意的话,你甚至可以使用MySQL++ API来创建自己的数据库引擎,就像打穿气缸装上自己的化油器.现在让我们来看看你该如何选择引擎,以及如何在可用引擎之间切换. 选择你的引擎 你能用的数据库引擎取

通过数据库引擎来加速MySQL数据库

如果你是个赛车手,并且按一下按钮就能够立即更换引擎而不需要把车开到车库里去换,那会是什么感觉呢?MySQL数据库为开发人员所做的就好像是按按钮换引擎:它让你选择数据库引擎,并给你一条简单的途径来切换它. MySQL的自带引擎肯定是够用了,但是在有些情况下,其他的引擎可能要比手头所用更适合完成任务.如果愿意的话,你甚至可以使用MySQL++ API来创建自己的数据库引擎,就像打穿气缸装上自己的化油器.现在让我们来看看你该如何选择引擎,以及如何在可用引擎之间切换. 选择你的引擎 你能用的数据库引擎取