如何解决基于数组变量的Azure数据工厂动态查询
我想在azure数据工厂内部创建一个带有动态查询的复制活动,基于数组变量,例如我只想加载数据库X的表A中的ID信息Y 数据库中的表 B。
与变量 ID_Variable 关联的集合变量活动中的代码是: 从 tableA 中选择不同的 ID;
我在复制活动中是这样尝试的: Select * from tableB where ID in (@variables('ID_Variable'));
但它没有用,提前致谢
解决方法
这是因为 IN 子句需要一个逗号分隔的引用值列表,例如 (1,2,3,4)
,但 ADF 中的数组值是 [1,4]。所以它没有用。
您需要将数组值更改为括在括号中的逗号分隔值。
最简单的方法是将您的第一个 SQL Select distinct ID from tableA
更改为
select stuff(
(
select distinct ','''+ CONVERT(VARCHAR(32),ID) +''''
from tableA
for xml path('')
),1,''
) as in_clause
如果可能的话。否则,您需要在 ADF 中使用额外的活动来执行此操作。 你可以参考这个error called Incorrect Syntax near in Azure DataFactory。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。