您可以采用两种不同的方法。
第一个是作为 user569711 概述并使用 ForEach Enumerator 并调用您现有的存储过程。这样做的好处是您的行为应该与您当前所经历的完全一样,并且您的测试只需要专注于确保 SSIS 包选择正确的文件。
第二种是使用 SSIS 的开箱即用功能来处理导入 BLOB 类型。
控制流
您将需要根据您的方法定义 1 到 2 个变量。两者都是字符串数据类型。我创建了SourceFolder
和CurrentFileName
. 前者定义了文件的来源并在任一方法中使用。后者在 ForEach 循环容器中用于捕获“当前”文件。
data:image/s3,"s3://crabby-images/7a1eb/7a1ebb411656de2e9ccce9b636431ef590935061" alt="控制流"
数据流
要使数据流正常工作,您需要将完全限定的文件名列表添加到管道中。最简单的方法是使用脚本转换,作为源并将其添加到所有满足您条件的文件(*.xml)中。
data:image/s3,"s3://crabby-images/325ec/325ec57550e16a8b09c011645e985485909ef988" alt="数据流"
Foreach 循环容器
像这样配置
收藏
data:image/s3,"s3://crabby-images/985e8/985e8adb5c831deee38ce9bbdf09257adb7f5a40" alt="在此处输入图像描述"
变量映射
data:image/s3,"s3://crabby-images/32809/328092b5653ccb82b9b6c43f918381c4670a4f92" alt="在此处输入图像描述"
执行 SQL 任务
如此配置
data:image/s3,"s3://crabby-images/055cc/055cc0ff57201a2988a271f4bc722fe1cf4bb74c" alt="在此处输入图像描述"
data:image/s3,"s3://crabby-images/acd14/acd14a176faf7aeed5b009bbdaa629574f7d0fac" alt="在此处输入图像描述"
脚本源
此任务会将可用文件添加到数据流中。次要注意,这将遍历与我们配置 Foreach 的方式不同的子文件夹。这是对第三个参数(或省略)的简单更改,使其仅位于顶层。
识别您的变量,使其在脚本任务中可用
data:image/s3,"s3://crabby-images/384a7/384a780c7de6d0fbd23afbb501de10d110872e0a" alt="在此处输入图像描述"
添加适当的输出列。您的长度可能因您的环境而异。
data:image/s3,"s3://crabby-images/62daf/62daf997dc06fb42d82e6148cd7067e6ff9bbcd6" alt="在此处输入图像描述"
脚本在这里
using System;
using System.Data;
using System.IO;
using Microsoft.SqlServer.Dts.Pipeline.Wrapper;
using Microsoft.SqlServer.Dts.Runtime.Wrapper;
[Microsoft.SqlServer.Dts.Pipeline.SSISScriptComponentEntryPointAttribute]
public class ScriptMain : UserComponent
{
public override void CreateNewOutputRows()
{
string fileMask = string.Empty;
string sourceFolder = string.Empty;
fileMask = @"*.xml";
sourceFolder = this.Variables.SourceFolder;
foreach (string fileName in Directory.GetFiles(sourceFolder, fileMask, SearchOption.AllDirectories))
{
Output0Buffer.AddRow();
Output0Buffer.FileName = fileName;
Output0Buffer.SourceName = "Dataflow";
}
}
}
导入列转换
像这样配置
data:image/s3,"s3://crabby-images/91493/9149369660e7398a1ee01347c7aee6f5ee469992" alt="在此处输入图像描述"
在此处记下 ID
data:image/s3,"s3://crabby-images/f0e4c/f0e4c8ca69d6476fe3b1a92957db2c61bbfc0cbc" alt="在此处输入图像描述"
将该 ID 绑定到具有名称的列
data:image/s3,"s3://crabby-images/cc96a/cc96ada4885669475a3090e5e0b6a7c39415e788" alt="在此处输入图像描述"
OLE DB 目标
配置。不支持快速加载选项。
data:image/s3,"s3://crabby-images/7d5c4/7d5c47be9aab585059fda8eecc89153c53e3132f" alt="在此处输入图像描述"
data:image/s3,"s3://crabby-images/e238f/e238f615080533b6ab6aada7e43f2879521d1126" alt="在此处输入图像描述"
参考
关于使用导入列转换的好帖子