单表导入/导出文本文件

王朝other·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

/*--实现数据导入/导出的存储过程

可以实现导入/导出 指定表 到文本文件

支持自定义行/列分隔符

--邹建 2003.07--*/

/*--调用示例

导出调用示例

--导出指定表,这里指定导出表:地区资料

exec file2table 'zj','','','c:\zj.txt','xzkh_new..地区资料',@rowsplit=','

导入调用示例

--导入指定表,这里指定导入表:地区资料

exec file2table 'zj','','','c:\zj.txt','xzkh_sa..地区资料',0

--*/

if exists(select 1 from sysobjects where name='File2Table' and objectproperty(id,'IsProcedure')=1)

drop procedure File2Table

go

create procedure File2Table

@servername varchar(200) --服务器名

,@username varchar(200) --用户名,如果用NT验证方式,则为空''

,@password varchar(200) --密码

,@filename varchar(1000) --目录名+文件名

,@tbname varchar(500)='' --数据库..表名

,@isout bit=1 --1为导出(默认),0为导入

,@fdsplit varchar(10)='\t' --字段分隔符,默认为制表符

,@rowsplit varchar(10)='\n' --记录分隔符,默认为回车符

as

declare @sql varchar(8000)

set @sql='bcp "'+@tbname

+case when @isout=1 then '" out' else '" in' end

+' "'+@filename+'" /c' +' /S"'+@servername

+case when isnull(@username,'')='' then ''

else '" /U"'+@username end

+'" /P"'+isnull(@password,'')+'"'

+' /t"'+@fdsplit+'"'

+' /r"'+@rowsplit+'"'

exec master..xp_cmdshell @sql

go

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航