
/*--实现数据导入/导出的存储过程
能够实现导入/导出 指定表 到文本文档 支持自定义行/列分隔符
--邹建 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
|