80分!!!急寻邹建等高手!!!

wangdehao 2004-12-22 07:49:13
公司需要每月将所有电话记录按地区分成17个表,如200412.0531,200412.0532等,然后再将表中的数据导出形成.txt文件,文件名跟对应的表名相同.请问怎么可以批量的把数据导出?用存储过程实现可行吗?
如果可行应怎样实现?
...全文
224 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiayouguo 2004-12-23
  • 打赏
  • 举报
回复
努力向各位大侠学习,,,,
zjcxc 2004-12-23
  • 打赏
  • 举报
回复
--参考这个:

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

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

可以实现导入/导出 整个数据库/指定表 到文本文件

--邹建 2003.07(引用请保留此信息)--*/

/*--调用示例

导出调用示例
--导出指定表,这里指定导出表:地区资料 和 基本信息,文件名前缀为:zj
exec file2table 'zj','','','d:\','xzkh_sa','地区资料,基本信息'
--导出整个数据库到c:\docman目录下,无文件前缀
exec file2table 'zj','','','d:\txt\','xzkh_sa'

导入调用示例
--导入指定表,这里指定导出表:地区资料 和 基本信息,文件名前缀为:zj
exec file2table 'zj','','','c:\zj','xzkh_sa','地区资料,基本信息',0
--导入整个数据库从c:\docman目录下,无文件前缀
exec file2table 'zj','','','C:\docman\','xzkh_sa','',0
--*/
create procedure File2Table
@servername varchar(200) --服务器名
,@username varchar(200) --用户名,如果用NT验证方式,则为空''
,@password varchar(200) --密码
,@path varchar(1000) --目录名+文件前缀,目录名必须以'\'结束,文件名自动用表名.txt
,@dbname varchar(500) --数据库名
,@tbname varchar(8000)='' --表名列表,如果不指定,则表示所有用户表
,@isout bit=1 --1为导出(默认),0为导入
as
declare @sql varchar(8000),@sql1 varchar(8000)
declare @tbstation int,@filestation int

--初始化数据处理语句
select @sql='bcp "'+@dbname+'..'
,@tbstation=len(@sql)+1
,@sql=@sql
+case when @isout=1 then '" out' else '" in' end
+' "'+@path
,@filestation=len(@sql)+1
,@sql=@sql
+'.txt" /c' +' /S"'+@servername
+case when isnull(@username,'')='' then ''
else '" /U"'+@username end
+'" /P"'+isnull(@password,'')+'"'

--数据导入/导出处理
--定义数据处理的游标
set @sql1='declare #tb cursor for select name from '
+@dbname+'..sysobjects where xtype=''U'''
+case when isnull(@tbname,'')='' then ''
else ' and name in ('''+replace(@tbname,',',''',''')+''')' end
exec(@sql1)
open #tb
fetch next from #tb into @tbname
while @@fetch_status=0
begin
select @sql1=stuff(@sql,@tbstation,0,@tbname)
,@sql1=stuff(@sql1,@filestation+len(@tbname),0,@tbname)
exec master..xp_cmdshell @sql1,no_output
fetch next from #tb into @tbname
end
close #tb
deallocate #tb
go
sky125 2004-12-23
  • 打赏
  • 举报
回复
mark
xuzhenhua21 2004-12-23
  • 打赏
  • 举报
回复
友情关注一下!
wangdehao 2004-12-23
  • 打赏
  • 举报
回复
先顶一下,晚上才能看贴结贴,如果不行,还要麻烦各位老大啊
vinsonshen 2004-12-22
  • 打赏
  • 举报
回复
declare #cursor cursor for select [name] from 库名.dbo.sysobjects where 条件 --此条件根据你的表名规律进行取适当条件,以便一次性把所有你要导出的表名放进一个游标里循环执行来进行导出~~~
vinsonshen 2004-12-22
  • 打赏
  • 举报
回复
说明:
上面生成的文件保存在c盘根目录下,你可以适当更改,-U后面是访问数据库的帐号(上面用的是SQL的sa帐号),-P后面的是该数据库帐号的登陆密码
vinsonshen 2004-12-22
  • 打赏
  • 举报
回复
set nocount on
declare @name sysname
declare #cursor cursor for select [name] from 库名.dbo.sysobjects where 条件 --此条件根据你的表名规律进行取适当条件
open #cursor
fetch next from #cursor into @name
while @@fetch_status=0
begin
exec ('exec master..xp_cmdshell ''bcp 库名.dbo.'+@name+' out c:\'+@name+'.txt -c -t , -Usa -Pmypassword''')
fetch next from #cursor into @name
end
set nocount off
guanshiyu123 2004-12-22
  • 打赏
  • 举报
回复
导出到TXT文本,用逗号分开
exec master..xp_cmdshell ’bcp "库名..表名" out "d:\文件名.txt" -c -t ,-U sa -P password’





wangdehao 2004-12-22
  • 打赏
  • 举报
回复
有高手吗?自己顶
xiayouguo 2004-12-22
  • 打赏
  • 举报
回复
纠正:如果是ASP则先把数据库内容读到 客户端数据集里,然后用FSO创建TXT文件并把客户端数据集中的东西写到TXT文件里。当然,如果你的数据库表里的记录有非常多,就要考虑连接超时问题,不要一次读写太久。

这种做法只能针对本地机器,即数据库和程序都在一台机器上
xiayouguo 2004-12-22
  • 打赏
  • 举报
回复
如果是ASP则可以,先把数据库内容读到 客户端数据集里,然后用FSO创建TXT文件并把客户端数据集中的东西写到TXT文件里。当然,如果你的数据库是远程的、表里的记录有非常多,就要考虑连接超时问题,不要一次读写太久。
xiayouguo 2004-12-22
  • 打赏
  • 举报
回复
你用的是什么程序语言?你的数据库是远程的还是本地的??
wangminlikeapple 2004-12-22
  • 打赏
  • 举报
回复
顺便帮我看下我那个问题啊...大哥

27,580

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧