Как решить "Не удалось найти устанавливаемый ISAM". ошибка для поставщика OLE DB "Microsoft.ACE.OLEDB.12.0"
Я пытаюсь импортировать данные из файлов Excel 2007 (.xlsx) в SQL Server 2008 с помощью команды T-SQL OpenRowset() с поставщиком OLEDB "Microsoft.ACE.OLEDB.12.0", и я получаю постоянный " Не удалось найти устанавливаемую ошибку "ISAM". Все оборудование 32-битное.
[Пересмотрено 1/10/12, чтобы попытаться сфокусироваться на аномалиях более резко]
Следующая инструкция T-SQL вызывает ошибку:
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0',
'Data Source=C:\work\TestData.xlsx;Extended Properties="Excel 12.0 XML;HDR=YES"',
'SELECT * FROM [Sheet1$]'
)
Если я сохраню файл Excel в формате "Excel 97-2003" (.xls) и использую более старый поставщик Microsoft.Jet.OLEDB.4.0 для импорта данных, он работает просто отлично. Это заставляет меня думать, что это не проблема безопасности или другая экологическая проблема.
SELECT * FROM OPENROWSET('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=C:\work\TestData.xls;HDR=YES',
'SELECT * FROM [Sheet1$]'
)
Однако, когда я пробую файл *.xls с поставщиком Microsoft.ACE.OLEDB.12.0, который должен быть обратно совместим с форматом *.xls, он снова завершается с той же ошибкой:
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0',
'Data Source=C:\work\TestData.xls;Extended Properties="Excel 8.0;HDR=YES";',
'SELECT * FROM [Sheet1$]'
)
Также, что интересно, когда я использую мастер SSMS "Импорт данных...", он работает нормально. Я сохранил выходные данные мастера импорта данных в виде пакета служб SSIS и посмотрел в файле служб SSIS, чтобы попытаться выяснить, как он работает, и он успешно работает с использованием поставщика Microsoft.ACE.OLEDB.12.0. Это строка подключения из пакета служб SSIS:
<DTS:Property DTS:Name="ConnectionString">
Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\work\TestData.xlsx;Extended Properties="Excel 12.0 XML;HDR=YES";
</DTS:Property>
Я также выполнил соответствующую настройку SQL Server, чтобы разрешить распределенный запрос OPENROWSET:
sp_configure 'show advanced options', 1
reconfigure
GO
sp_configure 'Ad Hoc Distributed Queries', 1
reconfigure
GO
Если я также установлю следующие значения *sp_MSset_oledb_prop* (которые я где-то нашел в посте)...
USE [master]
GO
EXEC master.dbo.sp_MSset_oledb_prop N'Microsoft.ACE.OLEDB.12.0', N'AllowInProcess', 1
GO
EXEC master.dbo.sp_MSset_oledb_prop N'Microsoft.ACE.OLEDB.12.0', N'DynamicParameters', 1
GO
... тогда ошибка изменится на "Unspecified error":
OLE DB provider "Microsoft.ACE.OLEDB.12.0" for linked server "(null)" returned message "Unspecified error".
Msg 7303, Level 16, State 1, Line 1
Cannot initialize the data source object of OLE DB provider "Microsoft.ACE.OLEDB.12.0" for linked server "(null)".
Тем не менее, я не уверен, является ли это восходящей или нисходящей ошибкой. (Теперь он находит "устанавливаемый ISAM", но впоследствии не работает?)
Я пробовал это с несколькими файлами Excel на двух разных машинах / ОС (Windows Server 2003, Windows XP SP3). Обе машины 32-битные.
Я также попытался переустановить версии AccessDatabaseEngine.exe для Office 2007 и Office 2010 ( http://www.microsoft.com/download/en/details.aspx?id=23734 и http://www.microsoft.com/download/en/details.aspx?id=13255 соответственно), но безрезультатно.
Подвести итоги:
- Поставщик "Microsoft.Jet.OLEDB.4.0" работает с использованием T-SQL, а "Microsoft.ACE.OLEDB.12.0" - нет.
- "Microsoft.ACE.OLEDB.12.0" работает с помощью мастера "Импорт данных..." (насколько я могу судить по сохраненному файлу задания SSIS).
- Установка для свойств "AllowInProcess" и "DynamicParameters" значения "1" приводит к изменению ошибки на "Unspecified error". (Это шаг вперед?!)
Какие-нибудь мысли?
9 ответов
НАКОНЕЦ, решение!
В основном вы идете в
Панель управления> Администрирование> Службы компонентов
затем расширить
Службы компонентов> Компьютеры> Мой компьютер> Конфигурация DCOM
находить
MSDAINITIALIZE
идти к
Свойства> Безопасность> Разрешения на запуск и активацию
нажмите на
Настройка> Изменить...
добавьте свой логин или "Все", если вы предпочитаете
отметьте ВСЕ поля "разрешить" для нового пользователя / группы
и нажмите ОК на обеих страницах
Теперь посмотрим, работает ли ваша команда OpenRowSet / OpenDataSource
Спасибо Рамешу Бабу Вавилле (vr.babu) из social.technet.microsoft.com за ссылку
Хай также столкнулся с этой ситуацией, я решил
решаемая
string ConeectionString = String.Format(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + txtFlp.Text
+ ";Extended Properties=\"Excel 12.0 Xml;HDR=YES\"");
OleDbConnection oconn = new OleDbConnection(ConeectionString);</b>
Попробуйте это может помочь вам:
задавать path
а также strFileType
согласно требованию
string connString = "";
// string strFileType = Path.GetExtension(UpfileName.FileName).ToLower();
// string path = UpfileName.PostedFile.FileName;
if (strFileType.Trim() == ".xls")
{
connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + path + ";Extended Properties=\"Excel 8.0;HDR=Yes;IMEX=2\"";
}
else if(strFileType.Trim() == ".xlsx")
{
connString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + path + ";Extended Properties=\"Excel 12.0;HDR=Yes;IMEX=2\"";
}
Это сработало для меня
Select *
FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0',
'text;
HDR=yes;
imex=1;
driver={Microsoft text Driver (*.xls, *.xlsx, *.xlsm, *.xlsb,*.csv)};
extended properties=excel 12.0 xml;
Database=<path>\',
'SELECT * from [<filename>#csv]')
Обеспечение цитат вокруг расширенного раздела свойств строки подключения исправило это для меня. Я добавил дополнительное свойство и не перенес цитату до конца после моего нового свойства.
Это сработало для меня:
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0',
'Excel 12.0;HDR=NO;Database=C:\temp\file.xlsx;',[sheetname$])
Я думаю, что ответ скрыт в информации о пакете служб SSIS, которую вы разместили. Новый формат файла xlsx хранит данные в формате XML вместо старого формата. Посмотри на это еще раз. Он читает... Расширенные свойства ="Excel 12.0 XML;HDR= ДА
Не пропустите этот XML после стандартных вещей. (Для чего это стоит, я также прочитал, что вам нужно "Excel 12.0 Macro" для соединения с файлом xslm.)
Попробуйте. Странно, но, надеюсь, это работает.
я решил этот запрос:
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0',
'Excel 12.0;HDR=NO;Database=D:\Filename.xlsx;',
[SheetName$])
Кажется, sql не нравится раздел "Расширенные свойства"...
Попробуй это
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0',
'EXCEL 12.0;DataBase=C:\TEMP\test.xlsx;Extended Properties="EXCEL 12.0 Xml;HDR=YES', [Sheet1$])
Если вы делаете весь этот пост и продолжаете с ошибкой. попробуйте назначить разрешение на папку pdf, аккаунту
NT Service\MSSQLSERVER
NT Service\SQLSERVERAGENT
работает для меня