Execute Statement

Runs a SQL statement/query on an AWS Redshift cluster

Description

This job asynchronously runs a query on an AWS Redshift cluster. Orchestra uses the boto3 python package to interact with your redshift cluster. The ExecuteStatement API is used, documentation can be found here.

Use Cases

We recommend creating an Execute Redshift statement task for every statement you wish to execute in Redshift.

In Redshift, pretty much everything you can do can be done using a query. This ranges from simple SQL statements to anything within the DDL/DML spectrum. Furthermore, you can also run Data Quality tests and clone tables using Redshift statements.

There are a number of advantages to triggering Redshift statements in Orchestra vs. other workflow orchestration tools:

  • You can co-ordinate tasks outside of Redshift - these would typically be other Redshift jobs, data loading steps, or other tasks in Redshift-adjacent environments e.g. dbt, a BI tool

  • You can use Orchestra to trigger jobs across Redshift Projects / Environments

  • When Redshift jobs run, Data Warehouse cost is incurred. Running these operations on a schedule you set explicitly ensures these costs do not go out of hand

  • We aggregate metadata from the Redshift Task in the same place as the metadata from other operations in your Pipeline

Parameters

These parameters are required to run the Execute Redshift statement task:

NameData typeRestrictionsExample

SQL Statement

String

Must be valid DML or DDL statement

SELECT * FROM TABLE

Cluster identifier

String

Optional (overrides value used in credential object) Value can be found in the AWS console when viewing the clusters configuration

dummy-cluster

Database name

String

Optional (overrides value used in credential object)

dummy-database

Database user

String

Optional (overrides value used in credential object)

Defined in the Redshift cluster. You can view the users in your cluster using select * from pg_user;

dummy-user

Region

String

Optional (overrides value used in credential object)

eu-west-1

Last updated