ETL问题解答-用SSIS将表导出到文件

问题: 百度商业智能贴吧的网友“花不完的幸福”提问: 数据库中有很多很多表,现在要求将其中四个表的数据导出到本地,本地文件命名要用表名+导出时间,我现在很纠结了。

第一点:要用一个包实现四个表导出,怎么做?无头绪
第二点:怎么才能指定本地文件名呢?还要用导出时间作为后缀的。
例:table :abc 导出后为:abc_201206030950.txt
table :ef 导出后为:ef_201306030955.txt

简答:

第一点:
完成一个包实现四个文件的导出有多种方法,比如:
1) 偷懒的话可以在Script脚本任务里完成所有工作,如果你熟悉脚本的话;
2)或者可以用一个控制流依次循环取四个表数据,就在控制流写文件;
3)还可以用四个数据流,分别从表中取数并装载到文件中;

将表名、文件名等用变量+Foreach循环控制,可以大大简化以上做法。

第二点:文件名的拼接可以在控制流里用ssis Script脚本任务,分别获取表名变量和当前时间并拼接,在Script脚本任务里拼接文件名比较容易。

因为文件名示例里的最小时间粒度是分钟,还需要判断自动调度或运行时会不会产生同名文件,如果有潜在同名文件的可能,还要考虑是否覆盖的问题。

维护地址:ETL问题解答-用SSIS将表导出到文件 (http://jbean.org/1593.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值