我有一个ssis包,我使用连接到SQL Server 2005表的OLEDB源。除日期列之外的所有列都是NVARCHAR(255)。我正在使用Excel目标并使用SQL语句在Excel工作簿中创建工作表,SQL位于Excel连接管理器(实际上是创建工作表的创建表语句)中,并且是从列的映射派生而来的。 DB。
无论我做了什么,我都会得到这个unicode - >源和目标之间的非unicode转换错误。尝试在S>之间转换为字符串[DT_STR]。 D,删除它,将SQL Table VARCHAR更改为NVARCHAR并仍然得到此flippin错误。
因为我使用SQL语句在Excel中创建工作表,所以我没有看到任何方法来实际预定义Excel工作表中列的数据类型。我想这将是一个默认的元数据,但我不知道。
因此,在我的SQL表目的地与使用此SSIS sql语句创建Excel表单之间,如何才能阻止此错误出现?
我的错误是:
数据流任务错误[OLE DB源[1]]:列“MyColumn”无法在unicode和非unicode字符串数据类型之间进行转换。
对于所有nvarchar列。
感谢任何帮助
由于
安德鲁
答案 0 :(得分:58)
添加数据转换转换,将字符串列从非Unicode(DT_STR)转换为Unicode(DT_WSTR)字符串。
您需要为所有字符串列执行此操作...
答案 1 :(得分:47)
以下步骤对我有用:
1)。右键单击源任务。
2)。单击"显示高级编辑器"。 advanced edit option for source task in ssis
3)。转到"输入和输出属性"标签
4)。选择要获得错误的输出列。
5)。其数据类型为" String [DT_STR]"。
6)。将该数据类型更改为" Unicode字符串[DT_WSTR]"。 Changing the data type to unicode string
7)。保存并关闭。 希望这可以帮助!
答案 2 :(得分:14)
首先,将数据转换块添加到数据流图中。
打开数据转换块并勾选显示错误的列。下面将其数据类型更改为unicode字符串(DT_WSTR)或预期的任何数据类型并保存。
转到目标栏。转到其中的映射并将新创建的元素映射到其对应的地址并保存。
在解决方案explorer.select属性中右键单击您的项目。选择配置属性并在其中选择调试。在这里,将Run64BitRunTime选项设置为false(因为excel不能很好地处理64位应用程序)。
答案 3 :(得分:7)
您可以将nvarchar列转换为varchar列,而不是添加先前建议的数据转换。这可以防止您进行不必要的步骤,并且具有比替代方案更高的性能。
在选择SQL语句时,将date
替换为CAST(date AS varchar([size]))
。由于某种原因,这还没有改变输出数据类型。为此,请执行以下操作:
执行此操作后,您的源数据将作为varchar输出,您的错误将消失。
答案 4 :(得分:4)
答案 5 :(得分:3)
当我安装了连接到运行在Windows上的Oracle 12 Server的Oracle 12版客户端32位客户端时,我遇到了这种情况。 尽管Oracle-source和SqlServer-destination都不是Unicode,但我仍然收到此消息,就像oracle列是Unicode一样。 我解决了插入数据转换盒的问题,以及 为varchar2字段选择DT-STR(不是unicode),为数字字段选择DT-WSTR(unicode),然后我删除了' COPY OF'从输出字段名称。 请注意,我一直收到错误,因为在设置转换类型之前,我已将源框箭头与转换框连接起来。所以我不得不切换源框,这清理了目标框中的所有错误。
答案 6 :(得分:2)
在上面的示例中,我一直在丢失值,我认为延迟验证将允许将新数据类型保存为元数据的一部分。
在“Excel连接管理器”的连接管理器上,从“属性”中将“延迟验证”设置为“假”。
然后在Excel的数据流目标任务上,再次从属性中将ValidationExternalMetaData设置为False。
现在,您可以右键单击Excel目标任务,然后转到Excel目标的高级编辑器 - >最右边的选项卡 - 输入和输出属性。在External Columns文件夹部分,您现在可以更改有问题列的数据类型和长度值,现在可以保存它。
祝你好运!
答案 7 :(得分:2)
似乎没有人提到这一点,但是,在源查询中将 varchar 转换为 nvarchar 也解决了这个问题。
答案 8 :(得分:1)
我一直有同样的问题,并尝试了这里写的所有内容,但它仍然给了我同样的错误。 在我试图转换的列中被证明是NULL值。
删除NULL值解决了我的问题。
干杯, 艾哈迈德
答案 9 :(得分:1)
在 SQL Server 中创建表时,将表列设为 NVARCHAR
而不是 VARCHAR
。
答案 10 :(得分:0)
我认为人们错过了这一点。就我而言,我有 100 个字符列要在 Oracle 和 MS Sql 之间进行转换。如果您有 100 个字符的列,所有这些关于数据转换和高级编辑器的内容都非常乏味。加上 SSIS 作为 SSIS,即使您将 VALIDATEEXTERNALMETADATA 设置为 false,它有时也会重置所有 100 个高级编辑器更改,这非常令人讨厌。如果有一些价值,我不介意进行数据转换,但是 20 年前,ETL 工具用于将 oracle 字符转换为 ms sql 字符而不会大惊小怪。如果您有很多字符列并且可以使用 nvarchar,那么 Bakalolo 和 Zafer 所说的就是答案,只需在 ms sql 中声明所有列 nvarchar。我还发现新的 Oracle Source (2021) 并没有抱怨在 ms sql 中将 unicode 转换为 varchar。