以下解决方案可能会帮助您解决问题。
将 For each 循环容器与"Item" enumerator
. 由于您有 10 个文件,如果缺少某些文件需要 raise,那么您应该使用它。文件枚举器只是遍历文件,不会引发任何错误。
以下是步骤。
使用变量创建以下 SSIS 包。
- 文件全路径
- 已验证
对于每个循环枚举器应配置为以下屏幕截图。
集合中的配置:
data:image/s3,"s3://crabby-images/bac08/bac082a19d15401275f7c0d94d6f95e7e09019d9" alt="在此处输入图像描述"
变量部分中的配置
data:image/s3,"s3://crabby-images/bdc82/bdc820827b7d99a7b89b4fda9be6c143147d845a" alt="在此处输入图像描述"
容器内部有一个脚本任务。您必须提及FileFullPath
as readonly 变量和IsValidate
read and write ,如下面的屏幕所示。
data:image/s3,"s3://crabby-images/0cd3f/0cd3f62d82fd13f33233f366c37847ab9420004f" alt="在此处输入图像描述"
单击编辑脚本并插入以下代码。
public void Main()
{
Dts.Variables["IsValidated"].Value = true;
string fileFullPath = Dts.Variables["FileFullPath"].Value.ToString();
if (!File.Exists(fileFullPath))
{
var msg = String.Format("File is not available in location : {0}", fileFullPath);
Dts.Events.FireError(0, "Dat file loading", msg, string.Empty, 0);
Dts.TaskResult = (int)ScriptResults.Failure;
}
//Read last line
String lstLine = File.ReadLines(fileFullPath).Last();
int totalCount = 0;
bool talierExists = int.TryParse(lstLine, out totalCount);
if (!talierExists)
{
var msg = String.Format("No tailer row found and last line is : {0}", lstLine);
Dts.Events.FireError(0, "Dat file loading", msg, string.Empty, 0);
Dts.TaskResult = (int)ScriptResults.Failure;
}
//Total count
int fullCount = File.ReadLines(fileFullPath).Count();
if (fullCount != totalCount)
{
var msg = String.Format("No of count is not matching, tailer count = {0} and full count={1}");
Dts.Events.FireError(0, "Dat file loading", msg, string.Empty, 0);
Dts.TaskResult = (int)ScriptResults.Failure;
}
Dts.Variables["IsValidated"].Value = true;
Dts.TaskResult = (int)ScriptResults.Success;
}
之后有你的数据流。将脚本任务与您的数据流连接,然后右键单击连接器并进行如下编辑和配置。
data:image/s3,"s3://crabby-images/8a294/8a294eba16de06d7e394a770debfc701b4604b84" alt="在此处输入图像描述"
您的 SSIS 包将如下所示。
data:image/s3,"s3://crabby-images/c5b53/c5b53560d354fe306ec4e505d9bf7cef190e74f1" alt="在此处输入图像描述"
希望这可以帮助!