使用字符串“NULL”值更改 SSIS 平面文件数据的数据类型

问题描述

在我的 SSIS 项目中,我必须从平面 csv 文件中检索我的数据。数据本身看起来像这样:

AccountType,SID,PersonID,FirstName,LastName,Email,Enabled
NOR,0001,Test,Test0001,[email protected],TRUE
NOR,1001,NULL,Test1002,[email protected],FALSE
TST,1002,Test1003,[email protected],TRUE

我需要读取这些数据并确保它具有正确的数据类型以供将来检查。意思是 SID 和 PersonID 应该有一个数字数据类型, Enabled 应该是一个布尔值。但我想保留与源文件相同的列和名称。

似乎通过“平面文件源”任务读取此数据的唯一正确方法是字符串。否则我会不断收到错误消息,因为“NULL”实际上是一个字符串,而不是一个 NULL 值。

接下来,我执行派生列转换以去除所有“NULL”值。例如,我对 PersonId 使用以下表达式:

(TRIM(PersonID) == "" || UPPER(PersonID) == "NULL") ? (DT_WSTR,50)NULL(DT_WSTR,50) : PersonID

我想通过在上面的表达式中添加它来立即将其转换为正确的数据类型,但是当我在派生列下拉框中选择“替换‘PersonId’”时,似乎不可能为同一列选择另一种数据类型。

所以接下来我想到使用旁边的数据转换任务来更改这些列的数据类型,但是当我使用它时它只会创建新列,即使我输入输出别名以保持不变。

我怎样才能改变我的解决方案以高效、正确地读取这些数据并将其值转换为正确的数据类型?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)