/*--實(shí)現數據導入/導出的存儲過(guò)程
可以實(shí)現導入/導出 指定表 到文本文件
支持自定義行/列分隔符
--鄒建 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) --服務(wù)器名
,@username varchar(200) --用戶(hù)名,如果用NT驗證方式,則為空‘‘
,@password varchar(200) --密碼
,@filename varchar(1000) --目錄名+文件名
,@tbname varchar(500)=‘‘ --數據庫..表名
,@isout bit=1 --1為導出(默認),0為導入
,@fdsplit varchar(10)=‘\t‘ --字段分隔符,默認為制表符
,@rowsplit varchar(10)=‘\n‘ --記錄分隔符,默認為回車(chē)符
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

