airflow.providers.amazon.aws.hooks.athena
¶
This module contains AWS Athena hook.
Module Contents¶
Classes¶
Interact with AWS Athena to run, poll queries and return query results |
- class airflow.providers.amazon.aws.hooks.athena.AthenaHook(*args, sleep_time=30, **kwargs)[source]¶
Bases:
airflow.providers.amazon.aws.hooks.base_aws.AwsBaseHook
Interact with AWS Athena to run, poll queries and return query results
Additional arguments (such as
aws_conn_id
) may be specified and are passed down to the underlying AwsBaseHook.See also
- Parameters
sleep_time (int) -- Time (in seconds) to wait between two consecutive calls to check query status on Athena
- run_query(query, query_context, result_configuration, client_request_token=None, workgroup='primary')[source]¶
Run Presto query on athena with provided config and return submitted query_execution_id
- Parameters
query (str) -- Presto query to run
query_context (Dict[str, str]) -- Context in which query need to be run
result_configuration (Dict[str, Any]) -- Dict with path to store results in and config related to encryption
client_request_token (Optional[str]) -- Unique token created by user to avoid multiple executions of same query
workgroup (str) -- Athena workgroup name, when not specified, will be 'primary'
- Returns
str
- Return type
- check_query_status(query_execution_id)[source]¶
Fetch the status of submitted athena query. Returns None or one of valid query states.
- get_state_change_reason(query_execution_id)[source]¶
Fetch the reason for a state change (e.g. error message). Returns None or reason string.
- get_query_results(query_execution_id, next_token_id=None, max_results=1000)[source]¶
Fetch submitted athena query results. returns none if query is in intermediate state or failed/cancelled state else dict of query output
- get_query_results_paginator(query_execution_id, max_items=None, page_size=None, starting_token=None)[source]¶
Fetch submitted athena query results. returns none if query is in intermediate state or failed/cancelled state else a paginator to iterate through pages of results. If you wish to get all results at once, call build_full_result() on the returned PageIterator
- Parameters
- Returns
PageIterator
- Return type
Optional[botocore.paginate.PageIterator]
- poll_query_status(query_execution_id, max_tries=None)[source]¶
Poll the status of submitted athena query until query state reaches final state. Returns one of the final states