首页 > 开发 > 综合 > 正文

单表导入/导出文本文件

2024-07-21 02:08:25
字体:
来源:转载
供稿:网友

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

 可以实现导入/导出 指定表 到文本文件
 支持自定义行/列分隔符

--邹建 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 "'[email protected]
 +case when @isout=1 then '" out' else '" in' end
 +' "'[email protected]+'" /c' +' /s"'[email protected]
 +case when isnull(@username,'')='' then ''
  else '" /u"'[email protected] end
 +'" /p"'+isnull(@password,'')+'"'
 +' /t"'[email protected]+'"'
 +' /r"'[email protected]+'"'

exec master..xp_cmdshell @sql
go



发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表