SQL Server与Excel数据互导

shignjiao251

shignjiao251

2016-01-29 16:23

SQL Server与Excel数据互导,SQL Server与Excel数据互导
 

从SQL Server中导入/导出 Excel 的基本方法

/*=================== 导入/导出 Excel 的基本方法 ===================*/

从Excel文件中,导入数据到SQL数据库中,很简单,直接用下面的语句:

/*========================================================*/

--如果接受数据导入的表已经存在

insert into 表 select * from

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/sqlserver/)

OPENROWSET('MICROSOFT.JET.OLEDB.4.0'

,'Excel 5.0;HDR=YES;DATABASE=c:test.xls',sheet1$)

--如果导入数据并生成表

select * into 表 from

OPENROWSET('MICROSOFT.JET.OLEDB.4.0'

,'Excel 5.0;HDR=YES;DATABASE=c:test.xls',sheet1$)

/*========================================================*/

--如果从SQL数据库中,导出数据到Excel,如果Excel文件已经存在,而且已经按照要接收的数据创建好表头,就可以简单的用:

insert into OPENROWSET('MICROSOFT.JET.OLEDB.4.0'

,'Excel 5.0;HDR=YES;DATABASE=c:test.xls',sheet1$)

select * from 表

--如果Excel文件不存在,也可以用BCP来导成类Excel的文件,注意大小写:

--导出表的情况

EXEC master..xp_cmdshell 'bcp 数据库名.dbo.表名 out "c:test.xls" /c -/S"服务器名" /U"用户名" -P"密码"'

--导出查询的情况

EXEC master..xp_cmdshell 'bcp "SELECT au_fname, au_lname FROM pubs..authors ORDER BY au_lname" queryout "c:test.xls" /c -/S"服务器名" /U"用户名" -P"密码"'

/*--说明:

c:test.xls 为导入/导出的Excel文件名.

sheet1$     为Excel文件的工作表名,一般要加上$才能正常使用.

--*/

--上面已经说过,用BCP导出的是类Excel文件,其实质为文本文件,

--要导出真正的Excel文件.就用下面的方法

/*--数据导出EXCEL

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/sqlserver/)

导出表中的数据到Excel,包含字段名,文件为真正的Excel文件

,如果文件不存在,将自动创建文件

,如果表不存在,将自动创建表

基于通用性考虑,仅支持导出标准数据类型

--邹建 2003.10--*/

/*--调用示例

p_exporttb @tbname='地区资料',@path='c:',@fname='aa.xls'

--*/

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_exporttb]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)

drop procedure [dbo].[p_exporttb]

GO

create proc p_exporttb

@tbname sysname,   --要导出的表名

@path nvarchar(1000),   --文件存放目录

@fname nvarchar(250)='' --文件名,默认为表名

as

declare @err int,@src nvarchar(255),@desc nvarchar(255),@out int

declare @obj int,@constr nvarchar(1000),@sql varchar(8000),@fdlist varchar(8000)

--参数检测

if isnull(@fname,'')='' set @fname=@tbname+'.xls'

--检查文件是否已经存在

if right(@path,1)<'' set @path=@path+''

create table #tb(a bit,b bit,c bit)

set @sql=@path+@fname

insert into #tb exec master..xp_fileexist @sql

--数据库创建语句

set @sql=@path+@fname

if exists(select 1 from #tb where a=1)

set @constr='DRIVER={Microsoft Excel Driver (*.xls)};DSN='''';READONLY=FALSE'

    +';CREATE_DB="   +';DATABASE='+@sql+'"'

--连接数据库 www.knowsky.com

exec @err=sp_oacreate 'adodb.connection',@obj out

if @err<0 goto lberr

exec @err=sp_oamethod @obj,'open',null,@constr

if @err<0 goto lberr

/*--如果覆盖已经存在的表,就加上下面的语句

--创建之前先删除表/如果存在的话

select @sql='drop table ['+@tbname+']'

exec @err=sp_oamethod @obj,'execute',@out out,@sql

--*/

--创建表的SQL

select @sql='',@fdlist=''

select @fdlist=@fdlist+',['+a.name+']'

,@sql=@sql+',['+a.name+'] '

+case when b.name in('char','nchar','varchar','nvarchar') then

  'text('+cast(case when a.length255 then 255 else a.length end as varchar)+')'

  when b.name in('tynyint','int','bigint','tinyint') then 'int'

  when b.name in('smalldatetime','datetime') then 'datetime'

  when b.name in('money','smallmoney') then 'money'

  else b.name end

FROM syscolumns a left join systypes b on a.xtype=b.xusertype

where b.name not in('image','text','uniqueidentifier','sql_variant','ntext','varbinary','binary','timestamp')

and object_id(@tbnam

展开更多 50%)
分享

猜你喜欢

SQL Server与Excel数据互导

SQLServer
SQL Server与Excel数据互导

SQL SERVER数据导成INSERT

SQLServer
SQL SERVER数据导成INSERT

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

SQL Server与Access、Excel的数据转换

SQLServer
SQL Server与Access、Excel的数据转换

SQL SERVER 与ACCESS、EXCEL的数据转换

编程语言 网络编程
SQL SERVER 与ACCESS、EXCEL的数据转换

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

SQL SERVER与ACCESS,EXCEL的数据转换C++

编程语言 网络编程
SQL SERVER与ACCESS,EXCEL的数据转换C++

精妙的SQL和SQL SERVER 与ACCESS、EXCEL的数据导入导出转换

编程语言 网络编程
精妙的SQL和SQL SERVER 与ACCESS、EXCEL的数据导入导出转换

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

photoshop教程:利用图层样式及滤镜制作闪亮的钻石字

photoshop教程:利用图层样式及滤镜制作闪亮的钻石字

未与信任SQL Server连接相关联的解决方法

未与信任SQL Server连接相关联的解决方法
下拉加载更多内容 ↓