CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
IBM Rational 系统开发最佳实践工具包 WebSphere MQ 最佳实践 TOP 15
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  基础类

邹版主,这个存储过程为什么第一次成功第二次就不成功?

楼主djdeng(djdeng)2006-03-04 11:29:44 在 MS-SQL Server / 基础类 提问

--??对一个表做第一次是成功,做第二次的时候就出问题  
  --0x80040E14 Microsoft   JET   Database   Engine 字段定义语法错误。  
  --  
   
  --下面的存储过程可以导出数据为真正的excel文件  
   
  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  
   
  /*--数据导出EXCEL  
   
  导出表中的数据到Excel,包含字段名,文件为真正的Excel文件  
  ,如果文件不存在,将自动创建文件  
  ,如果表不存在,将自动创建表  
  基于通用性考虑,仅支持导出标准数据类型  
   
  --邹建   2003.10(引用请保留此信息)--*/  
   
  /*--调用示例  
   
  p_exporttb   @tbname='地区资料',@path='c:\',@fname='aa.xls'  
  --*/  
  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="'+@sql+'";DBQ='+@sql  
  else  
  set   @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended   Properties="Excel   8.0;HDR=YES'  
  +';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   like   '%char'    
  then   case   when   a.length>255   then   'memo'  
  else   'text('+cast(a.length   as   varchar)+')'   end  
  when   b.name   like   '%int'   or   b.name='bit'   then   'int'  
  when   b.name   like   '%datetime'   then   'datetime'  
  when   b.name   like   '%money'   then   'money'  
  when   b.name   like   '%text'   then   'memo'  
  else   b.name   end  
  FROM   syscolumns   a   left   join   systypes   b   on   a.xtype=b.xusertype  
  where   b.name   not   in('image','uniqueidentifier','sql_variant','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   8.0;HDR=YES;IMEX=1  
  ;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  
  问题点数:50、回复次数:5Top

1 楼fdsfasdfdas()回复于 2006-03-04 12:35:40 得分 0

upTop

2 楼wgsasd311(自强不息)回复于 2006-03-04 13:20:05 得分 0

--try  
  --下面的存储过程可以导出数据为真正的excel文件  
  select   *   from   authors  
  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  
   
  /*--数据导出EXCEL  
   
  导出表中的数据到Excel,包含字段名,文件为真正的Excel文件  
  ,如果文件不存在,将自动创建文件  
  ,如果表不存在,将自动创建表  
  基于通用性考虑,仅支持导出标准数据类型  
   
  --邹建   2003.10(引用请保留此信息)--*/  
   
  /*--调用示例  
  p_exporttb   @tbname='test',@path='c:\',@fname='aa.xls'  
  --*/  
  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="'+@sql+'";DBQ='+@sql  
  else  
  set   @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended   Properties="Excel   8.0;HDR=YES'  
  +';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  
  --*/  
  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   like   '%char'    
  then   case   when   a.length>255   then   'memo'  
  else   'text('+cast(a.length   as   varchar)+')'   end  
  when   b.name   like   '%int'   or   b.name='bit'   then   'int'  
  when   b.name   like   '%datetime'   then   'datetime'  
  when   b.name   like   '%money'   then   'money'  
  when   b.name   like   '%text'   then   'memo'  
  else   b.name   end  
  FROM   syscolumns   a   left   join   systypes   b   on   a.xtype=b.xusertype  
  where   b.name   not   in('image','uniqueidentifier','sql_variant','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   8.0;HDR=YES;IMEX=1  
  ;DATABASE='+@path+@fname+''',['+@tbname+'$])'  
   
  exec('insert   into   '+@sql+'('+@fdlist+')   select   '+@fdlist+'   from   '+@tbname)  
   
  return  
   
  lberr:  
  exec   sp_oageterrorinfo   0,@src   out,@desc   out  
  select   '1'  
  lbexit:  
  select   cast(@err   as   varbinary(4))   as   错误号  
  ,@src   as   错误源,@desc   as   错误描述  
  select   @sql,@constr,@fdlist  
  go  
   
  Top

3 楼wgsasd311(自强不息)回复于 2006-03-04 13:32:54 得分 0

--try  
  --下面的存储过程可以导出数据为真正的excel文件  
  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  
   
  /*--数据导出EXCEL  
   
  导出表中的数据到Excel,包含字段名,文件为真正的Excel文件  
  ,如果文件不存在,将自动创建文件  
  ,如果表不存在,将自动创建表  
  基于通用性考虑,仅支持导出标准数据类型  
   
  --邹建   2003.10(引用请保留此信息)--*/  
   
  /*--调用示例  
  p_exporttb   @tbname='test',@path='c:\',@fname='aa.xls'  
  --*/  
  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="'+@sql+'";DBQ='+@sql  
  else  
  set   @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended   Properties="Excel   8.0;HDR=YES'  
  +';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  
  --*/  
  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   like   '%char'    
  then   case   when   a.length>255   then   'memo'  
  else   'text('+cast(a.length   as   varchar)+')'   end  
  when   b.name   like   '%int'   or   b.name='bit'   then   'int'  
  when   b.name   like   '%datetime'   then   'datetime'  
  when   b.name   like   '%money'   then   'money'  
  when   b.name   like   '%text'   then   'memo'  
  else   b.name   end  
  FROM   syscolumns   a   left   join   systypes   b   on   a.xtype=b.xusertype  
  where   b.name   not   in('image','uniqueidentifier','sql_variant','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   8.0;HDR=YES;IMEX=1  
  ;DATABASE='+@path+@fname+''',['+@tbname+'$])'  
   
  exec('insert   into   '+@sql+'('+@fdlist+')   select   '+@fdlist+'   from   '+@tbname)  
   
  return  
   
  lberr:  
  exec   sp_oageterrorinfo   0,@src   out,@desc   out  
  select   '1'  
  lbexit:  
  select   cast(@err   as   varbinary(4))   as   错误号  
  ,@src   as   错误源,@desc   as   错误描述  
  select   @sql,@constr,@fdlist  
  go  
   
  Top

4 楼zhouhaihe()回复于 2006-03-04 13:41:11 得分 0

upTop

5 楼gaojier1000(V2※高捷)回复于 2006-03-04 14:05:05 得分 0

学习!Top

相关问题

  • 为什么存储过程不成功???
  • 如何确定存储过程是否成功执行?
  • 如何判断系统存储过程是否执行成功?????
  • 请教@@error,存储过程是否执行成功的问题!!
  • 怎样判断存储过程是否执行成功
  • 邹大哥~~存储过程中,如何调用其他存储过程的查询结果啊?
  • 复杂的存储过程(邹建进来看看,在线等)
  • 怎样调用 邹建 的分页存储过程 ?????
  • SQL Server版的这个存储过程在ORACLE里,如何写???
  • 谁有《SQL Server 2000存储过程与XML编程》电子版?

关键词

  • 文件
  • excel
  • 存储过程
  • 数据
  • 语句
  • 数据库
  • hdr
  • 导出
  • fdlist
  • exporttb

得分解答快速导航

  • 帖主:djdeng

相关链接

  • SQL Server类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo