您的位置:首页 > 数据库 > SQL

SQL SERVER使用OpenRowset,、OpenDataSource函数导入、导出数据到Excel 的几种方法(整理)

2013-09-23 10:18 816 查看
一、如我在D盘下有D:/物件编码.xls文件,有工作表名Sheet是中文命名为‘办公用品编码’,‘零件编码’。

select * into #temp from
opendatasource('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=D:/物件编码.xls')...[办公用品编码$]

select * into #temp from
opendatasource('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=D:/物件编码.xls')...[零件编码$]

二、如你的Excel文件是工作表是默认的Sheet命名为Sheet1,Sheet2等。

select * into #temp from
opendatasource('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=D:/物件编码.xls')...[Sheet1$]

select * into #temp from
opendatasource('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=D:/物件编码.xls')...[Sheet2$]

三、引用 Limpire (昨夜小楼)以下方法,也行

OpenRowSet和OpenDataSource都能用读取用数字命名的Sheet,只不过要加单引号界定,其它不规则命名的Sheet也一样。

假设C:/Text.xls有个Sheet名字是“3”:

select
* from
opendatasource('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=C:/Test.xls')...['3$']

--OR

select
* from
openrowset('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=C:/Test.xls',['3$'])

--OR

select
* from
openrowset('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=C:/Test.xls','select * from [''3$'']')

--OpenRowSet(,,'query')可以不加单引号界定:

select
* from
openrowset('Microsoft.Jet.OLEDB.4.0',
'Excel 8.0;Database=C:/Test.xls','select * from [3$]')

四、本人的方法:

导出EXCEL时,对应字段数类型都要相同,EXCEL字段的名称stano,sname 和数据库的要一样,才能导出成功。

insert into openrowset('MICROSOFT.JET.OLEDB.4.0','excel 8.0;

HDR=YES;database=D:/FName.xls',sheet1$)

select stano,sname from stainfo

以上在SQL SERVER2000上测试均可以运行,是在本地查询分析器中调试。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: