使用输出参数时执行SQL任务时出错

2022-03-31 00:00:00 sql etl sql-server ssis execute-sql-task

我要从SQL Server表中检索最新日期。

在执行SQL任务的&q;中,我有以下SQL语句:

SELECT ? = MAX(MYDATE) --SQL data type of this column is datetime
FROM TBLLOG
WHERE COMPLETED = 1

在参数映射部分下,我添加了1个输出参数:

  • 变量名:User:var_testdt(注意:这是DateTime类型)
  • 方向:输出
  • 日期类型:日期
  • 参数名称:0
  • 参数大小:-1

执行SQL";任务的ResultSet属性设置为None。

我在执行包时遇到此错误:

.失败,出现以下错误:
调用COM组件返回错误HRESULT E_FAIL。
可能的失败原因:查询有问题,";ResultSet";属性设置不正确,参数设置不正确,或连接建立不正确。


解决方案

这是数据类型问题。

基于SQL Server official documentation,将SSIS中的DT_DBTIMESTAMP数据类型映射到SQL Server中的datetimesmalldatetime数据类型。而DT_DATE未映射到任何数据类型。

要解决此问题,只需将输出参数的数据类型从DATE更改为DBTIMESTAMP。此外,确保User:var_testdt变量也是DateTime

相关文章