<%@ page contentType="text/html; charset=gb2312"%> sqlserver与excel数据互导解答
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
sqlserver与excel数据互导解答
     发布者: 发布时间:2006-05-07
从sql server中导入/导出 excel 的基本方法


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

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

/*===================================================================*/
--如果接受数据导入的表已经存在
insert into 表 select * from
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

导出表中的数据到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+''"''


--连接数据库
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.length>255 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(@tbname)=id
select @sql=''create table [''+@tbname
+''](''+substring(@sql,2,8000)+'')''
,@fdlist=substring(@fdlist,2,8000)
exec @err=sp_oamethod @obj,''execute'',@out out,@sql
if @err<>0 goto lberr

exec @err=sp_oadestroy @obj

--导入数据
set @sql=''openrowset(''''microsoft.jet.oledb.4.0'''',''''excel 5.0;hdr=yes
  ;database=''+@path+@fname+'''''',[''+@tbname+''$])''

exec(''insert into ''+@sql+''(''+@fdlist+'') select ''+@fdlist+'' from ''+@tbname)

return

lberr:
exec sp_oageterrorinfo 0,@src out,@desc out
lbexit:
select cast(@err as varbinary(4)) as 错误号
,@src as 错误源,@desc as 错误描述
select @sql,@constr,@fdlist
go
--上面是导表的,下面是导查询语句的.

/*--数据导出excel

导出查询中的数据到excel,包含字段名,文件为真正的excel文件
,如果文件不存在,将自动创建文件
,如果表不存在,将自动创建表
基于通用性考虑,仅支持导出标准数据类型
--邹建 2004.10--*/

/*--调用示例

p_exporttb @sqlstr=''select * from 地区资料''
,@path=''c:'',@fname=''aa.xls'',@sheetname=''地区资料''
--*/
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
@sqlstr varchar(8000),   --查询语句,如果查询语句中使用了order by ,请加上top 100 percent
@path nvarchar(1000),   --文件存放目录
@fname nvarchar(250),   --文件名
@sheetname varchar(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=''temp.xls''
if isnull(@sheetname,'''')='''' set @sheetname=replace(@fname,''.'',''#'')

--检查文件是否已经存在
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+''"''

--连接数据库
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

--创建表的sql
declare @tbname sysname
set @tbname=''##tmp_''+convert(varchar(38),newid())
set @sql=''select * into [''+@tbname+''] from(''+@sqlstr+'') a''
exec(@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.length>255 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 tempdb..syscolumns a left join tempdb..systypes b on a.xtype=b.xusertype
where b.name not in(''image'',''text'',''uniqueidentifier'',''sql_variant'',''ntext'',''varbinary'',''binary'',''timestamp'')
and a.id=(select id from tempdb..sysobjects where name=@tbname)
select @sql=''create table [''+@sheetname
+''](''+substring(@sql,2,8000)+'')''
,@fdlist=substring(@fdlist,2,8000)

exec @err=sp_oamethod @obj,''execute'',@out out,@sql
if @err<>0 goto lberr

exec @err=sp_oadestroy @obj

--导入数据
set @sql=''openrowset(''''microsoft.jet.oledb.4.0'''',''''excel 5.0;hdr=yes
  ;database=''+@path+@fname+'''''',[''+@sheetname+''$])''

exec(''insert into ''+@sql+''(''+@fdlist+'') select ''+@fdlist+'' from [''+@tbname+'']'')

set @sql=''drop table [''+@tbname+'']''
exec(@sql)
return

lberr:
exec sp_oageterrorinfo 0,@src out,@desc out
lbexit:
select cast(@err as varbinary(4)) as 错误号
,@src as 错误源,@desc as 错误描述
select @sql,@constr,@fdlist
go

(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
sqlserver连接基础知识
浅析sqlserver一个没有公开的存储过程
数据库考试简介——微软数据库管理员(mcdba)
可供选择的聚合
一些关于sqlserver2000的安全配置
调整sqlserver2000运行中数据库结构
 
最近评论:
        
你曾悄悄的来过!
wow gold,wow gold,wow gold,ffxi gil max(1361)
        
冰封的往事!
wow power leveling,wow gold,wow power leveling,wow gold max(8635)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(2006)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(6812)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(9518)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(2084)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(6710)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(7119)
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号