cancel
Showing results forย 
Search instead forย 
Did you mean:ย 
Data Engineering
Join discussions on data engineering best practices, architectures, and optimization strategies within the Databricks Community. Exchange insights and solutions with fellow data engineers.
cancel
Showing results forย 
Search instead forย 
Did you mean:ย 

Can SQL task pass its outputs to ForEach task?

Fikrat
New Contributor II

Hi there,
If I understood correctly, Roland said output SQL task can be used as input to ForEach task in Workflows. I tried that and used the expression sqlTaskName.output.rows, but Databricks rejected that expression. Anyone know how to do that? 

1 ACCEPTED SOLUTION

Accepted Solutions

Walter_C
Databricks Employee
Databricks Employee

Our internal teams has confirmed that this is currently not working on your side as this feature is currently in Private preview we will need to wait for some time until it is fully released.

View solution in original post

6 REPLIES 6

Walter_C
Databricks Employee
Databricks Employee

Can you confirm if this are the steps being followed:

  • Create the SQL Task: Ensure your SQL task is correctly set up and produces the desired output. For example:

    SELECT customer_name, market FROM example_customers;
  • Reference the SQL Task Output in ForEach Task:

    • Use the correct syntax to reference the rows output. The expression should be in the format {{ tasks.sqlTaskName.output.rows }}.
    • Ensure that the SQL task name (sqlTaskName) matches the task key you have defined in your workflow.
  • Configure the ForEach Task:

    • Set the inputs field of the ForEach task to {{ tasks.sqlTaskName.output.rows }}.
    • Define the nested task within the ForEach task to process each row. For example:
      {
        "task_key": "process_customers_iteration",
        "parameters": {
          "customer_name": "{{ input.customer_name }}",
          "market": "{{ input.market }}"
        },
        "sql_task": {
          "file": {
            "path": "/path/to/your/sql/file.sql"
          }
        }
      }

 

 

Fikrat
New Contributor II

Hi there,

Thanks for looking at this. I followed your instructions to the letter, but Databricks refused to accept that dynamic expression for the input of foreach task, see the screenshot.And output.rows expression is not among dynamic expressions offered by 'Inputs' box.Also, I can't even save that setting for ForEach task, let alone to execute it. Please advise.

Walter_C
Databricks Employee
Databricks Employee

May I know from which blog or webinar did you get the information provided in the original post?

Fikrat
New Contributor II

I got it from this:
What's New in Databricks Workflows - with Live Demos!
He's demoing haw sql task output can be consumed at around 9-th min

Walter_C
Databricks Employee
Databricks Employee

I am asking internally on this, will get back to you once I have more details

Walter_C
Databricks Employee
Databricks Employee

Our internal teams has confirmed that this is currently not working on your side as this feature is currently in Private preview we will need to wait for some time until it is fully released.

Connect with Databricks Users in Your Area

Join a Regional User Group to connect with local Databricks users. Events will be happening in your city, and you wonโ€™t want to miss the chance to attend and share knowledge.

If there isnโ€™t a group near you, start one and help create a community that brings people together.

Request a New Group