Подключение файлов MS Excel — различия между версиями
Строка 7: | Строка 7: | ||
В данной статье описывается пример подключения Excel-файла '''sample.xlsx''' на примере сервера '''MSSQL 2008 SP3 x64'''. | В данной статье описывается пример подключения Excel-файла '''sample.xlsx''' на примере сервера '''MSSQL 2008 SP3 x64'''. | ||
− | '''Шаг 1.''' Для начала работы скачайте провайдера '''Microsoft.ACE.OLEDB.12.0''' по ссылке http://www.microsoft.com/en-us/download/details.aspx?id=13255. | + | '''Шаг 1.''' Для начала работы скачайте установочные файлы провайдера '''Microsoft.ACE.OLEDB.12.0''' по ссылке http://www.microsoft.com/en-us/download/details.aspx?id=13255. |
Если у вас 64-битная версия SQL Server используйте установочный файл ''AccessDatabaseEngine_x64.exe''. | Если у вас 64-битная версия SQL Server используйте установочный файл ''AccessDatabaseEngine_x64.exe''. | ||
Строка 58: | Строка 58: | ||
==Подключение с помощью Microsoft Jet 4.0 Ole DB Provider == | ==Подключение с помощью Microsoft Jet 4.0 Ole DB Provider == | ||
− | + | Скачайте установочные файлы провайдера по ссылке http://www.microsoft.com/en-us/download/details.aspx?id=23734. | |
− | <span style="color:red;"> | + | <span style="color:red;">Технология Jet 4.0 работает только на 32-битных версиях MSSQL. |
+ | Для создания связанного сервера используйте следующий SQL-запрос: | ||
− | + | <pre> EXEC sp_addlinkedserver 'ExcelSource', 'Jet 4.0', 'Microsoft.Jet.OLEDB.4.0', | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | <pre> | + | |
− | EXEC sp_addlinkedserver 'ExcelSource', 'Jet 4.0', 'Microsoft.Jet.OLEDB.4.0', | + | |
'c:\MyData\DistExcl.xls', NULL, 'Excel 8.0' | 'c:\MyData\DistExcl.xls', NULL, 'Excel 8.0' | ||
− | EXEC sp_addlinkedsrvlogin 'ExcelSource', 'false', NULL, NULL | + | EXEC sp_addlinkedsrvlogin 'ExcelSource', 'false', NULL, NULL </pre> |
− | + | ||
− | </pre> | + | |
Версия 08:57, 30 сентября 2014
Содержание
Подключение с помощью Microsoft.ACE.OLEDB.12.0
В данной статье описывается пример подключения Excel-файла sample.xlsx на примере сервера MSSQL 2008 SP3 x64.
Шаг 1. Для начала работы скачайте установочные файлы провайдера Microsoft.ACE.OLEDB.12.0 по ссылке http://www.microsoft.com/en-us/download/details.aspx?id=13255.
Если у вас 64-битная версия SQL Server используйте установочный файл AccessDatabaseEngine_x64.exe.
Шаг 2. Для установки провайдера используйте запуск файла через командную строку с ключом /passive.
C:\AccessDatabaseEngine_x64.exe /passive
Шаг 3. Чтобы прилинковать Excel файл выполните следующие запросы в SQL Server Management Studio
exec sp_addlinkedserver @server = 'XlsLnkSrv', @srvproduct = 'ACE 12.0', @provider = 'Microsoft.ACE.OLEDB.12.0', @datasrc = 'C:\Sample.xlsx', @provstr = 'Excel 12.0; HDR=Yes'
где
- XlsLnkSrv - название связанного сервера
- C:\Sample.xlsx - абсолютный путь к требуемому Excel-файлу
Считать данные можно с помощью команды
select * from openquery (XlsLnkSrv, 'Select * from [Sheet1$]')
ВНИМАНИЕ: При возникновении ошибки Cannot get the column information from OLE DB provider "Microsoft.ACE.OLEDB.12.0" for linked server "(null)" выполните следующий запрос:
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
Используемые материалы: http://habrahabr.ru/post/219415/ и http://social.msdn.microsoft.com
Подключение с помощью Microsoft Jet 4.0 Ole DB Provider
Скачайте установочные файлы провайдера по ссылке http://www.microsoft.com/en-us/download/details.aspx?id=23734.
Технология Jet 4.0 работает только на 32-битных версиях MSSQL.
Для создания связанного сервера используйте следующий SQL-запрос:
EXEC sp_addlinkedserver 'ExcelSource', 'Jet 4.0', 'Microsoft.Jet.OLEDB.4.0', 'c:\MyData\DistExcl.xls', NULL, 'Excel 8.0' EXEC sp_addlinkedsrvlogin 'ExcelSource', 'false', NULL, NULL
Для получения данных из Excel необходимо, чтобы исходный XLS файл с данными содержал именованные диапазоны.
Пример запроса:
Select * From [Excel]...[Лист1$]