2016-07-08 91 views
0

我正在尝试编写一个批处理文件,它从Excel电子表格中获取信息并向SQL Server中添加新行。将Excel数据插入到SQL Server表的批处理文件

我认为我目前的工作已经快到了。当它运行并且说一条线被更新了,但它没有。

这是我的批处理文件:

@echo off 

copy \\RDS-2012-C\2012_N_Drive\Operations\Reports\Metrics\sql2.xlsx C:\ACCESS_SQLSVR\import_location 
sqlcmd -S RDS-2012-G\RDS_SQL -d Master -i C:\ACCESS_SQLSVR\import_location\sesame_import.sql 

pause 

而这正是它运行:

EXEC sp_configure 'Show Advanced Options', 1; 
RECONFIGURE 
GO 

EXEC sp_configure 'Ad Hoc Distributed Queries', 1; 
RECONFIGURE 
GO 

EXEC sp_MSSet_oledb_prop N'Microsoft.ACE.OLEDB.12.0', N'AllowInProcess', 1; 
GO 

EXEC sp_MSSet_oledb_prop N'Microsoft.ACE.OLEDB.12.0', N'DynamicParameters', 1; 
GO 

SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0', 
'Excel 12.0;Database=C:\ACCESS_SQLSVR\import_location\sql2.xlsx;HDR=YES;IMEX=1', 
'SELECT * FROM [SQL$]') 
GO 

难道我只是需要一个不同的命令,而不是SELECT

此外,SQL Server中的完整数据库和表被称为:

Sesame_FTest.dbo.SQL 

运行此当表不存在于表结果被创建和填充Excel的信息。但是用新的Excel第二次运行它并不像我想象的那样更新。

回答

0

试试吧。 。 。

------ INSERT INTO NON-EXISTING TABLES 

USE [YourDatabase] 
GO 

SELECT * INTO tbl_Mapping 
FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0', 
     'Excel 12.0 Xml;HDR=YES;Database=C:\Users\rshuell001\Desktop\State Street\Final Deliverables\Raw Data\Mapping.xlsx', 
     'SELECT * FROM [Mapping$]') 

SELECT * INTO tbl_Data 
FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0', 
     'Excel 12.0 Xml;HDR=YES;Database=C:\Users\rshuell001\Desktop\State Street\Final Deliverables\Raw Data\Data.xlsx', 
     'SELECT * FROM [Data$]') 

OR。 。 。

------ INSERT INTO EXISTING TABLES 

USE [YourDatabase] 
GO 
Insert INTO tbl_Mapping 
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0', 
     'Excel 12.0 Xml;HDR=YES;Database=C:\Users\rshuell001\Desktop\State Street\Final Deliverables\Raw Data\Mapping.xlsx', 
     'SELECT * FROM [Mapping$]') 


Insert INTO tbl_Data 
SELECT * FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0', 
     'Excel 12.0 Xml;HDR=YES;Database=C:\Users\rshuell001\Desktop\State Street\Final Deliverables\Raw Data\Data.xlsx', 
     'SELECT * FROM [Data$]') 
相关问题