微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Azure 数据工厂 -> 查找、ForEach 和复制活动

如何解决Azure 数据工厂 -> 查找、ForEach 和复制活动

我想从天蓝色突触中取出一个文件,并使用 ADf 将其加载到 ADL 中。我想读取过去 13 个月的数据并为每个月制作不同的文件。 我制作了一个 CSV 文件,我在其中写入了每个月的开始日期和结束日期,并对该文件进行了查找活动。然后使用 foreach 活动,我从复制活动加载文件。 现在我想为每个月的数据编写一个查询

select * from edw.factbaldly where INSERT_DATE > @activity('Lookup1').output.value.startdate and INSERT_DATE

select * from edw.factbaldly where INSERT_DATE > @item().startdate and INSERT_DATE

我使用这些进行查询,但无法读取查找活动的数据并获取数据。 请帮我查询。 提前致谢。

解决方法

我假设您的 Lookup1 CSV 列标题是 startdateenddate

在您的 ForEach > Settings > Items 中,您将拥有 @activity('Lookup1').output.value

在 ForEach 块内,您的复制活动源查询将如下所示:

select * from edw.factbaldly where INSERT_DATE > '@{item().startdate}' and INSERT_DATE < '@{item().enddate}'

ADF 会将 @{thing} 替换为字符串,因此您将在查询中将日期作为带引号的字符串获取

也许您还想要其中一个符号为 >= 或

实际上,您可能不需要维护 CSV,因为您可以使用变量和 ADF 函数 utcnow()、addToTime() 和 startOfMonth() 来查找日期

,

在查找活动中,您将获取@item().startdate 和@item().EndDate。或者我猜你已经在 ForEach 之前的查找中设置了这些。但是要在生成新文件时使用此详细信息,您必须使用复制活动源部分中问题的查询。

如果您不能直接在文件上使用查询,您可以将整个文件导入数据库表,然后在复制活动源中使用您的查询。

,

你可以使用这样的表达

 @concat('select * from edw.factbaldly where INSERT_DATE> >',item().startdate,'and INSERT_DATE <',item().EndDate)

如果我在你那里,我可以添加一个设置变量活动并测试上面的表达式。 set 变量应该给我们一个语法正确的 TSQL 语句。 HTH

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?