码迷,mamicode.com
首页 > 数据库 > 详细

sql sever读取Excel总结【转】

时间:2016-12-24 13:57:03      阅读:291      评论:0      收藏:0      [点我收藏+]

标签:one   任务   extend   mon   程序   检索   str   没有   row   

主要用到openrowset,opendatasource系统函数,这两个函数任意一个都能完成任务

用这种方法可以实现Excel和sqlserver表之间的相互导入导出。

 

openrowset的写法

技术分享
--3,链接Excel Microsoft Jet 4.0 OLE DB Provider
--读Excel数据,注意Excel必须事先关闭
select * 
from
openrowset(Microsoft.Jet.OLEDB.4.0‘,Excel 8.0;HDR=Yes;DATABASE=E:/Temp/myExcel20131212.xls, Sheet1$) 

--将数据写入Excel2003文件
--注意:首先需要对Excel的Sheet1的第一行设置与检索列相等的一些值,可以是任意值,
--但最好与列名相同;另外oledb可能对Excel没有写权限,需要对Excel表格的属性--》安全中加一个everyone权限
insert  into   
OPENROWSET(Microsoft.Jet.OLEDB.4.0‘,Excel 8.0;HDR=Yes;DATABASE=E:/Temp/myExcel20131212.xls,Sheet1$)   
select *  from  dbo.DQuestionData 
技术分享

opendatasource的写法

select * 
from
opendatasource(Microsoft.Jet.OLEDB.4.0‘,Excel 8.0;HDR=Yes;DATABASE=E:/Temp/myExcel20131212.xls‘)...Sheet1$

上面的代码是链接Excel2003的,对于Excel2007的链接 ,由于oledb提供程序不同,所以链接方式会不同。

下面附一个不同的链接方式,也是从网上找到的。

技术分享
--> Jet 引擎访问 Excel 97-2003  
select * from OpenRowSet(Microsoft.Jet.OLEDB.4.0‘, Excel 8.0;HDR=Yes;IMEX=1;Database=D:/97-2003.xls‘, select * from [Sheet1$])  
select * from OpenRowSet(Microsoft.Jet.OLEDB.4.0‘, Excel 8.0;HDR=Yes;IMEX=1;Database=D:/97-2003.xls‘, [Sheet1$])  
select * from OpenDataSource(Microsoft.Jet.OLEDB.4.0‘, Excel 8.0;HDR=Yes;IMEX=1;Database=D:/97-2003.xls‘)...[Sheet1$]  
select * from OpenDataSource(Microsoft.Jet.OLEDB.4.0‘, Data Source=D:/97-2003.xls;Extended Properties="Excel 8.0;HDR=Yes;IMEX=1"‘)...[Sheet1$]  
  
--> ACE 引擎访问 Excel 97-2003  
select * from OpenRowSet(Microsoft.ACE.OLEDB.12.0‘, Excel 12.0;HDR=Yes;IMEX=1;Database=D:/97-2003.xls‘, select * from [Sheet1$])  
select * from OpenRowSet(Microsoft.ACE.OLEDB.12.0‘, Excel 12.0;HDR=Yes;IMEX=1;Database=D:/97-2003.xls‘, [Sheet1$])  
select * from OpenDataSource(Microsoft.ACE.OLEDB.12.0‘, Excel 12.0;HDR=Yes;IMEX=1;Database=D:/97-2003.xls‘)...[Sheet1$]  
select * from OpenDataSource(Microsoft.ACE.OLEDB.12.0‘, Data Source=D:/97-2003.xls;Extended Properties="Excel 12.0;HDR=Yes;IMEX=1"‘)...[Sheet1$]  
  
--> ACE 引擎访问 Excel 2007  
select * from OpenRowSet(Microsoft.ACE.OLEDB.12.0‘, Excel 12.0;HDR=Yes;IMEX=1;Database=D:/2007.xlsx‘, select * from [Sheet1$])  
select * from OpenRowSet(Microsoft.ACE.OLEDB.12.0‘, Excel 12.0;HDR=Yes;IMEX=1;Database=D:/2007.xlsx‘, [Sheet1$])  
select * from OpenDataSource(Microsoft.ACE.OLEDB.12.0‘, Excel 12.0;HDR=Yes;IMEX=1;Database=D:/2007.xlsx‘)...[Sheet1$]  
select * from OpenDataSource(Microsoft.ACE.OLEDB.12.0‘, Data Source=D:/2007.xlsx;Extended Properties="Excel 12.0;HDR=Yes;IMEX=1"‘)...[Sheet1$]  
技术分享

 

sql sever读取Excel总结【转】

标签:one   任务   extend   mon   程序   检索   str   没有   row   

原文地址:http://www.cnblogs.com/bluedy1229/p/6217108.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!