ITPub博客

首页 > Linux操作系统 > Linux操作系统 > SQL Server 数据库常用导入导出Excel操作和命令

SQL Server 数据库常用导入导出Excel操作和命令

原创 Linux操作系统 作者:oracle_8i 时间:2010-08-17 16:26:22 0 删除 编辑
在查询分析器中,查询excel2007 表格中的数据
SELECT *
FROM OpenDataSource( 'MICROSOFT.ACE.OLEDB.12.0',
'Data Source="c:\book1.xlsx";User ID=Admin;Password=;Extended properties="Excel 12.0;HDR=Yes"')...[Sheet1$]

   这个地方,参数的写法中,“Excel 12.0”还可以换成”Excel 5.0“,”Excel 8.0“,”Excel 12.0“,换成其它的参数都不行,会报错。估计是excel版本命名的问题。

将SQL Server中某个表的数据,写入到已经存在的,有表头的Excel文件中:
  insert into OPENROWSET('MICROSOFT.ACE.OLEDB.12.0','Excel 8.0;HDR=yes;DATABASE=c:\book1.xlsx','select * from [Sheet1$]')(RegionID,RegionDescription)
select RegionID, RegionDescription from dbo.Region
  或者写成:
    insert into OPENROWSET('MICROSOFT.ACE.OLEDB.12.0','Excel 8.0;HDR=yes;DATABASE=c:\book1.xlsx','select * from [Sheet1$]')
select RegionID, RegionDescription from dbo.Region
也可以!

 但是,  有的网友写成这样:
   insert into OPENROWSET('MICROSOFT.ACE.OLEDB.12.0','Excel 8.0;HDR=yes;DATABASE=c:\book1.xlsx',sheet1$)  select * from dbo.Region
  就会发现,只能插入一行数据,并报错提示;

导出excel表格
EXEC master..xp_cmdshell 'BCP BIUserInforDB.dbo.t_edm out C:\test.xlsx -c -U"sa" -P"mypwd"'

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7311285/viewspace-671178/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2007-11-28

  • 博文量
    37
  • 访问量
    122724