Я не думаю, что вы можете "запросить" электронную таблицу, используя DAO или ADO.
Вы действительно можете запросить книгу Excel с помощью ADO у поставщика OLE DB для Access (Jet, что угодно). Подробнее см. в этой статье MSDN .
ADODB больше не поддерживается в Access 2007/2010,
Это не тот случай. Я думаю, вы, должно быть, что-то неправильно поняли, что неудивительно, если учесть, что в Access есть много глупостей, связанных с «ADO vs DAO» в Access.
Я не совсем уверен, что произошло, когда класс ADO был представлен сообществу Access2000, но, похоже, многие старожилы остались с обиженным эго / гордостью. Маркетинговое послание от Microsoft действовало: «DAO - это старый способ работы, а ADO - новый». В намеренном шаге MS новые функции двигателя, как правило, были доступны только через ADO.
Как часто бывает, когда под угрозой закрепляются позиции, давние поклонники Access + DAO встречали обратное движение. Это часто принимало форму «бросай достаточно грязи, а некоторые будут прилипать». Люди, недавно прибывшие в AccessLand, будут смущены смешанными сообщениями. В новостных группах начинающие MVP Access эмулировали позицию анти-ADO существующих MVP Access.
Между выпусками 200 и 2007 продукт Access стал IMO несколько устаревшим с точки зрения механизма, ответственность за который была передана команде SQL Server, которая на практике отказалась от него: их попытки сделать это Соответствие стандарту начального уровня SQL-92 были сорваны командой Windows, компоненты которой опирались на функции, которые бросали вызов стандарту. Классическая команда ADO была также расформирована. Visual Basic COM, который эффективно разделял библиотеки VBA с пакетом Office, был убит в пользу VB.NET, и родился ADO.NET,
Команда Access2007 снова встряхнулась. Они восстановили движок команд SQL Server и Windows, взяв частную ветку. Они отказались от безопасности на уровне пользователя, по-видимому, потому что это было слишком сложно для них поддерживать. Они добавили многозначные типы, которые, возможно, нарушают 1NF. Смелый материал! В то время как некоторые функции можно было бы разместить в ADO classic, создав новый поставщик OLE DB для Access, другие не смогли. Например, полная поддержка (например, обновление через SQL) для многозначных типов данных в ADO потребует изменения классических библиотек ADO, которыми группа Access не владеет.
Поскольку DAO принадлежала Access, в новой версии (называемой ACEDAO) появились функции, которых не хватало бы новому поставщику OLE DB со старыми классическими библиотеками ADO (хотя ADO требовалось использовать движок на 64-битных машинах). Однако они не сделали ретроспективного исправления DAO, чтобы приспособить функционал эры Access2000, который входил только в ADO.
Естественно, команда Access выдвинула ACEDAO в качестве первоклассного гражданина. Конечно, давние поклонники Access + DAO были в восторге: «ADO устарела в пользу ADO.NET», - кричали они. По правде говоря, чистый результат - смешанная сумка. См. эту тему для получения полной информации.