AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 27.01.2011, 12:11   #1  
Poleax is offline
Poleax
Модератор
Аватар для Poleax
MCP
MCBMSS
Злыдни
 
1,353 / 595 (22) +++++++
Регистрация: 17.02.2005
Адрес: msk
Записей в блоге: 34
? Метод "open" в COM-объекте класса "ADODB.Connection" возвратил код ошибки 0x80004005 (E_FAIL)
Есть проблема с пакетником на рабочем сервере.
Получаю ошибку:
Метод "open" в COM-объекте класса "ADODB.Connection" возвратил код ошибки 0x80004005 (E_FAIL), который означает: [Microsoft][Диспетчер драйверов ODBC] Источник данных не найден и не указан драйвер, используемый по умолчанию.
Суть пакетника: подключится к DBF файлам на удаленном сервере и прочитать данные.

Проект один и тот же на DEV, TEST, и рабочей Аксапте.
На DEV, TEST отрабатывает нормально в пакетном режиме. (ОС Windows Server 2003 SP2 x86)
На рабочей аксапте (ОС Windows Server 2008 SP2 64-bit) нормально отрабатывает только в ручном режиме, а пакетном режиме валится с ошибкой.

На что обратить внимание для решения проблемы?

P.S. Kernal version: 5.0.1500.3761
Application version: 5.0.1500.2985
__________________

This posting is provided "AS IS" with no warranties, and confers no rights.
Старый 27.01.2011, 12:18   #2  
AX2009
Гость
 
n/a
Цитата:
Сообщение от Poleax Посмотреть сообщение

На что обратить внимание для решения проблемы?
на то, где исполняется код
Старый 27.01.2011, 13:00   #3  
Poleax is offline
Poleax
Модератор
Аватар для Poleax
MCP
MCBMSS
Злыдни
 
1,353 / 595 (22) +++++++
Регистрация: 17.02.2005
Адрес: msk
Записей в блоге: 34
Цитата:
Сообщение от AX2009 Посмотреть сообщение
на то, где исполняется код
поясни
__________________

This posting is provided "AS IS" with no warranties, and confers no rights.
Старый 27.01.2011, 13:06   #4  
AX2009
Гость
 
n/a
Оксапта есть 3-tier приложение - Клиент, АОС и БД.

Х++ код может исполняться на двух из них - Клиент и АОС. Дальше, надеюсь, сам догадаешься.
Старый 27.01.2011, 13:25   #5  
Poleax is offline
Poleax
Модератор
Аватар для Poleax
MCP
MCBMSS
Злыдни
 
1,353 / 595 (22) +++++++
Регистрация: 17.02.2005
Адрес: msk
Записей в блоге: 34
Цитата:
Сообщение от AX2009 Посмотреть сообщение
Оксапта есть 3-tier приложение - Клиент, АОС и БД.

Х++ код может исполняться на двух из них - Клиент и АОС. Дальше, надеюсь, сам догадаешься.
Это ясно. В пакетнике он исполняется на АОС сервере.
У меня две аксапты DEV и TEST нормально отрабатывают.


Похоже причина все таки в разрядности ОС x86 или 64-bit.
Использую драйвер Microsoft.Jet.OLEDB.4.0
На Windows Server 2003 имеем список драйверов


На Windows Server 2008 драйвер Microsoft.Jet.OLEDB.4.0 не видно.


Помогите разобраться и понять как добавить драйвер Microsoft.Jet.OLEDB.4.0 в Windows Server 2008.

P.S. что то я запутался
__________________

This posting is provided "AS IS" with no warranties, and confers no rights.
Старый 27.01.2011, 13:41   #6  
someOne is offline
someOne
Участник
Аватар для someOne
 
173 / 429 (15) +++++++
Регистрация: 11.12.2008
Адрес: Москва
Возможно, что использовать этот драйвер ODBC на стороне АОС (в случае x64 платформы) вообще не получится. Мне этого не удалось. Пришлось перевести пакетную обработку функции, использующую ODBC доступ к DBF в режим запуска через клиента (так же как это работало в Ax 3.0)

Может быть кому то удалось найти компонент (ODBC, NET) который может "нормально" читать и писать DBF в режиме x64 ?

"нормально" имеется ввиду:
- высокая скорость чтения - записи
- возможность программно устанавливать кодировку (codePage) файла DBF
Старый 27.01.2011, 13:47   #7  
AX2009
Гость
 
n/a
А сообщение на это не намекало?
Кагбы логично сначала, проверить то, что написано в сообщении об ошибке
Старый 27.01.2011, 14:30   #8  
Poleax is offline
Poleax
Модератор
Аватар для Poleax
MCP
MCBMSS
Злыдни
 
1,353 / 595 (22) +++++++
Регистрация: 17.02.2005
Адрес: msk
Записей в блоге: 34
:(
Цитата:
Сообщение от someOne Посмотреть сообщение
Возможно, что использовать этот драйвер ODBC на стороне АОС (в случае x64 платформы) вообще не получится. Мне этого не удалось. Пришлось перевести пакетную обработку функции, использующую ODBC доступ к DBF в режим запуска через клиента (так же как это работало в Ax 3.0)
Похоже ты прав.
__________________

This posting is provided "AS IS" with no warranties, and confers no rights.
Старый 31.01.2011, 18:02   #9  
Poleax is offline
Poleax
Модератор
Аватар для Poleax
MCP
MCBMSS
Злыдни
 
1,353 / 595 (22) +++++++
Регистрация: 17.02.2005
Адрес: msk
Записей в блоге: 34
:(
Цитата:
Сообщение от Poleax Посмотреть сообщение
Есть проблема с пакетником на рабочем сервере.
Получаю ошибку:
Метод "open" в COM-объекте класса "ADODB.Connection" возвратил код ошибки 0x80004005 (E_FAIL), который означает: [Microsoft][Диспетчер драйверов ODBC] Источник данных не найден и не указан драйвер, используемый по умолчанию.
Ответ дан в статье http://support.microsoft.com/kb/957570/
Цитата:
Мы не предоставляем 64-разрядной версии поставщика Microsoft OLE DB для Jet. Кроме того мы не предоставляем 64-разрядной версии драйвера Jet ODBC. При использовании поставщика Microsoft OLE DB для Jet или драйвер ODBC для Jet для подключения к источнику данных в 64-разрядной среде возникают различные проблемы.

Ссылки по теме:
__________________

This posting is provided "AS IS" with no warranties, and confers no rights.
Старый 01.12.2011, 17:13   #10  
leva is offline
leva
Участник
 
52 / 36 (2) +++
Регистрация: 03.08.2005
Удалось заставить работать с 64-битными Windows и AOS-ом с помощью Microsoft ACE OLEDB, устанавливаемому с Microsoft Access Database Engine 2010 Redistributable.

ConnectionString при этом такой:
X++:
strfmt("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=%1;Extended Properties=dBASE IV;Persist Security Info=False", _path)
Проверял только экспорт. DAX 2009.
За это сообщение автора поблагодарили: Ace of Database (3), gl00mie (2).
Старый 01.12.2011, 21:28   #11  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
См. также Обработка DBF через .net
Старый 02.12.2011, 08:40   #12  
miklenew is offline
miklenew
Участник
Аватар для miklenew
MCBMSS
1C
Лучший по профессии 2009
 
1,688 / 433 (18) +++++++
Регистрация: 10.07.2006
Адрес: г. Ликино-Дулёво
То же сталкнулся в 1С с подобной проблемой.
Смыл такой получился. Сервер 1С запускался в 64 разрядном режиме, соответственно и к Access он обращался тоже в 64 разрядном режиме через 64 разрядный ODBC.
Не решаемой проблемой оказалось, если в базе есть связь с Access2.0 и ты как раз обращаешся к этой таблице. Не хочет выполнять запрос и всё тут.
Если к таблицам более новых версий, то там всё нормально.
А так как на предприятие до сих пор хватает таких баз, решили отказатся вообще от этой затеи. Чтоб не думалось то ли взлетит то ли нет. И так два дня убил на это.
Теперь пакетчик крутится на отдельном компе в клиентском режиме.
MS - must die
__________________
Энергия молодых и неравнодушных способна изменить мир к лучшему.
Старый 02.12.2011, 09:02   #13  
leva is offline
leva
Участник
 
52 / 36 (2) +++
Регистрация: 03.08.2005
gl00mie, да тоже был вариант найти .net-компонент для импорта-экспорта dbf, ну или в крайнем случае написать таковой. Отлично, что он уже написан, найден, доработан и даже обкатан. Для текущих скромных выгрузок нам ACE сгодится, но я возьму на заметку на будущее.

miklenew, где-то встречал вариант установки промежуточного звена в виде SQL Server (возможно даже Express подойдет). Т.е. в нем создается линк на dbf (или mdb в вашем случае), а AOS в свою очередь линкуется к SQL Server-у. Как это практически настраивается и заработает ли - не знаю, просто встретил мысль, но копать не стал, может вам пригодится.
Старый 06.09.2013, 16:53   #14  
Damn is offline
Damn
Участник
 
436 / 154 (6) ++++++
Регистрация: 28.05.2003
Адрес: в глуши
Цитата:
Сообщение от leva Посмотреть сообщение
Удалось заставить работать с 64-битными Windows и AOS-ом с помощью Microsoft ACE OLEDB
У меня что-то не получается. Метод open() выдаёт ошибку :

Метод "Open" в COM-объекте класса "ADODB.Connection" возвратил код ошибки 0x80004005 (E_FAIL), который означает: Невозможно найти устанавливаемый ISAM.

На сервере Microsoft Access Database Engine 2010 Redistributable установлен, 64-битная версия.
__________________
Дмитрий
Старый 01.10.2013, 14:15   #15  
Damn is offline
Damn
Участник
 
436 / 154 (6) ++++++
Регистрация: 28.05.2003
Адрес: в глуши
Цитата:
Сообщение от leva Посмотреть сообщение
Удалось заставить работать с 64-битными Windows и AOS-ом с помощью Microsoft ACE OLEDB, устанавливаемому с Microsoft Access Database Engine 2010 Redistributable.
Заработал у меня наконец ваш ConnectionString на стороне сервера, но только при использовании System.Data.OleDb.OleDbConnection, а не COM-объекта ADODB.Connection.
__________________
Дмитрий
Теги
.net, 64-bit, dbf, odbc, законченный пример, полезное, экспорт/импорт

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Передача массива в метод COM-объекта Вадим DAX: Программирование 6 24.01.2005 12:31
Variant Array и метод COM обекта TravellerInTime DAX: Программирование 11 09.07.2004 11:13
как вызвать метод "деда" ? Omeo DAX: Программирование 23 26.05.2004 16:07
Вопрос совсем "зеленый". Куда приткнуть метод? Hobo DAX: Программирование 3 13.02.2004 18:07
Метод класса, возвращающий сумму налога. 2.5SP5 studentLPC DAX: Программирование 2 25.07.2003 12:21

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 02:54.