com.amazonaws.services.athena.model.QueryExecution Maven / Gradle / Ivy
/*
* Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
package com.amazonaws.services.athena.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Information about a single instance of a query execution.
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class QueryExecution implements Serializable, Cloneable, StructuredPojo {
/**
*
* The unique identifier for each query execution.
*
*/
private String queryExecutionId;
/**
*
* The SQL query statements which the query execution ran.
*
*/
private String query;
/**
*
* The type of query statement that was run. DDL
indicates DDL query statements. DML
* indicates DML (Data Manipulation Language) query statements, such as CREATE TABLE AS SELECT
.
* UTILITY
indicates query statements other than DDL and DML, such as SHOW CREATE TABLE
,
* or DESCRIBE TABLE
.
*
*/
private String statementType;
/**
*
* The location in Amazon S3 where query and calculation results are stored and the encryption option, if any, used
* for query results. These are known as "client-side settings". If workgroup settings override client-side
* settings, then the query uses the location for the query results and the encryption configuration that are
* specified for the workgroup.
*
*/
private ResultConfiguration resultConfiguration;
/**
*
* Specifies the query result reuse behavior that was used for the query.
*
*/
private ResultReuseConfiguration resultReuseConfiguration;
/**
*
* The database in which the query execution occurred.
*
*/
private QueryExecutionContext queryExecutionContext;
/**
*
* The completion date, current state, submission time, and state change reason (if applicable) for the query
* execution.
*
*/
private QueryExecutionStatus status;
/**
*
* Query execution statistics, such as the amount of data scanned, the amount of time that the query took to
* process, and the type of statement that was run.
*
*/
private QueryExecutionStatistics statistics;
/**
*
* The name of the workgroup in which the query ran.
*
*/
private String workGroup;
/**
*
* The engine version that executed the query.
*
*/
private EngineVersion engineVersion;
/**
*
* A list of values for the parameters in a query. The values are applied sequentially to the parameters in the
* query in the order in which the parameters occur.
*
*/
private java.util.List executionParameters;
/**
*
* The kind of query statement that was run.
*
*/
private String substatementType;
/**
*
* The unique identifier for each query execution.
*
*
* @param queryExecutionId
* The unique identifier for each query execution.
*/
public void setQueryExecutionId(String queryExecutionId) {
this.queryExecutionId = queryExecutionId;
}
/**
*
* The unique identifier for each query execution.
*
*
* @return The unique identifier for each query execution.
*/
public String getQueryExecutionId() {
return this.queryExecutionId;
}
/**
*
* The unique identifier for each query execution.
*
*
* @param queryExecutionId
* The unique identifier for each query execution.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withQueryExecutionId(String queryExecutionId) {
setQueryExecutionId(queryExecutionId);
return this;
}
/**
*
* The SQL query statements which the query execution ran.
*
*
* @param query
* The SQL query statements which the query execution ran.
*/
public void setQuery(String query) {
this.query = query;
}
/**
*
* The SQL query statements which the query execution ran.
*
*
* @return The SQL query statements which the query execution ran.
*/
public String getQuery() {
return this.query;
}
/**
*
* The SQL query statements which the query execution ran.
*
*
* @param query
* The SQL query statements which the query execution ran.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withQuery(String query) {
setQuery(query);
return this;
}
/**
*
* The type of query statement that was run. DDL
indicates DDL query statements. DML
* indicates DML (Data Manipulation Language) query statements, such as CREATE TABLE AS SELECT
.
* UTILITY
indicates query statements other than DDL and DML, such as SHOW CREATE TABLE
,
* or DESCRIBE TABLE
.
*
*
* @param statementType
* The type of query statement that was run. DDL
indicates DDL query statements.
* DML
indicates DML (Data Manipulation Language) query statements, such as
* CREATE TABLE AS SELECT
. UTILITY
indicates query statements other than DDL and
* DML, such as SHOW CREATE TABLE
, or DESCRIBE TABLE
.
* @see StatementType
*/
public void setStatementType(String statementType) {
this.statementType = statementType;
}
/**
*
* The type of query statement that was run. DDL
indicates DDL query statements. DML
* indicates DML (Data Manipulation Language) query statements, such as CREATE TABLE AS SELECT
.
* UTILITY
indicates query statements other than DDL and DML, such as SHOW CREATE TABLE
,
* or DESCRIBE TABLE
.
*
*
* @return The type of query statement that was run. DDL
indicates DDL query statements.
* DML
indicates DML (Data Manipulation Language) query statements, such as
* CREATE TABLE AS SELECT
. UTILITY
indicates query statements other than DDL and
* DML, such as SHOW CREATE TABLE
, or DESCRIBE TABLE
.
* @see StatementType
*/
public String getStatementType() {
return this.statementType;
}
/**
*
* The type of query statement that was run. DDL
indicates DDL query statements. DML
* indicates DML (Data Manipulation Language) query statements, such as CREATE TABLE AS SELECT
.
* UTILITY
indicates query statements other than DDL and DML, such as SHOW CREATE TABLE
,
* or DESCRIBE TABLE
.
*
*
* @param statementType
* The type of query statement that was run. DDL
indicates DDL query statements.
* DML
indicates DML (Data Manipulation Language) query statements, such as
* CREATE TABLE AS SELECT
. UTILITY
indicates query statements other than DDL and
* DML, such as SHOW CREATE TABLE
, or DESCRIBE TABLE
.
* @return Returns a reference to this object so that method calls can be chained together.
* @see StatementType
*/
public QueryExecution withStatementType(String statementType) {
setStatementType(statementType);
return this;
}
/**
*
* The type of query statement that was run. DDL
indicates DDL query statements. DML
* indicates DML (Data Manipulation Language) query statements, such as CREATE TABLE AS SELECT
.
* UTILITY
indicates query statements other than DDL and DML, such as SHOW CREATE TABLE
,
* or DESCRIBE TABLE
.
*
*
* @param statementType
* The type of query statement that was run. DDL
indicates DDL query statements.
* DML
indicates DML (Data Manipulation Language) query statements, such as
* CREATE TABLE AS SELECT
. UTILITY
indicates query statements other than DDL and
* DML, such as SHOW CREATE TABLE
, or DESCRIBE TABLE
.
* @return Returns a reference to this object so that method calls can be chained together.
* @see StatementType
*/
public QueryExecution withStatementType(StatementType statementType) {
this.statementType = statementType.toString();
return this;
}
/**
*
* The location in Amazon S3 where query and calculation results are stored and the encryption option, if any, used
* for query results. These are known as "client-side settings". If workgroup settings override client-side
* settings, then the query uses the location for the query results and the encryption configuration that are
* specified for the workgroup.
*
*
* @param resultConfiguration
* The location in Amazon S3 where query and calculation results are stored and the encryption option, if
* any, used for query results. These are known as "client-side settings". If workgroup settings override
* client-side settings, then the query uses the location for the query results and the encryption
* configuration that are specified for the workgroup.
*/
public void setResultConfiguration(ResultConfiguration resultConfiguration) {
this.resultConfiguration = resultConfiguration;
}
/**
*
* The location in Amazon S3 where query and calculation results are stored and the encryption option, if any, used
* for query results. These are known as "client-side settings". If workgroup settings override client-side
* settings, then the query uses the location for the query results and the encryption configuration that are
* specified for the workgroup.
*
*
* @return The location in Amazon S3 where query and calculation results are stored and the encryption option, if
* any, used for query results. These are known as "client-side settings". If workgroup settings override
* client-side settings, then the query uses the location for the query results and the encryption
* configuration that are specified for the workgroup.
*/
public ResultConfiguration getResultConfiguration() {
return this.resultConfiguration;
}
/**
*
* The location in Amazon S3 where query and calculation results are stored and the encryption option, if any, used
* for query results. These are known as "client-side settings". If workgroup settings override client-side
* settings, then the query uses the location for the query results and the encryption configuration that are
* specified for the workgroup.
*
*
* @param resultConfiguration
* The location in Amazon S3 where query and calculation results are stored and the encryption option, if
* any, used for query results. These are known as "client-side settings". If workgroup settings override
* client-side settings, then the query uses the location for the query results and the encryption
* configuration that are specified for the workgroup.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withResultConfiguration(ResultConfiguration resultConfiguration) {
setResultConfiguration(resultConfiguration);
return this;
}
/**
*
* Specifies the query result reuse behavior that was used for the query.
*
*
* @param resultReuseConfiguration
* Specifies the query result reuse behavior that was used for the query.
*/
public void setResultReuseConfiguration(ResultReuseConfiguration resultReuseConfiguration) {
this.resultReuseConfiguration = resultReuseConfiguration;
}
/**
*
* Specifies the query result reuse behavior that was used for the query.
*
*
* @return Specifies the query result reuse behavior that was used for the query.
*/
public ResultReuseConfiguration getResultReuseConfiguration() {
return this.resultReuseConfiguration;
}
/**
*
* Specifies the query result reuse behavior that was used for the query.
*
*
* @param resultReuseConfiguration
* Specifies the query result reuse behavior that was used for the query.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withResultReuseConfiguration(ResultReuseConfiguration resultReuseConfiguration) {
setResultReuseConfiguration(resultReuseConfiguration);
return this;
}
/**
*
* The database in which the query execution occurred.
*
*
* @param queryExecutionContext
* The database in which the query execution occurred.
*/
public void setQueryExecutionContext(QueryExecutionContext queryExecutionContext) {
this.queryExecutionContext = queryExecutionContext;
}
/**
*
* The database in which the query execution occurred.
*
*
* @return The database in which the query execution occurred.
*/
public QueryExecutionContext getQueryExecutionContext() {
return this.queryExecutionContext;
}
/**
*
* The database in which the query execution occurred.
*
*
* @param queryExecutionContext
* The database in which the query execution occurred.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withQueryExecutionContext(QueryExecutionContext queryExecutionContext) {
setQueryExecutionContext(queryExecutionContext);
return this;
}
/**
*
* The completion date, current state, submission time, and state change reason (if applicable) for the query
* execution.
*
*
* @param status
* The completion date, current state, submission time, and state change reason (if applicable) for the query
* execution.
*/
public void setStatus(QueryExecutionStatus status) {
this.status = status;
}
/**
*
* The completion date, current state, submission time, and state change reason (if applicable) for the query
* execution.
*
*
* @return The completion date, current state, submission time, and state change reason (if applicable) for the
* query execution.
*/
public QueryExecutionStatus getStatus() {
return this.status;
}
/**
*
* The completion date, current state, submission time, and state change reason (if applicable) for the query
* execution.
*
*
* @param status
* The completion date, current state, submission time, and state change reason (if applicable) for the query
* execution.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withStatus(QueryExecutionStatus status) {
setStatus(status);
return this;
}
/**
*
* Query execution statistics, such as the amount of data scanned, the amount of time that the query took to
* process, and the type of statement that was run.
*
*
* @param statistics
* Query execution statistics, such as the amount of data scanned, the amount of time that the query took to
* process, and the type of statement that was run.
*/
public void setStatistics(QueryExecutionStatistics statistics) {
this.statistics = statistics;
}
/**
*
* Query execution statistics, such as the amount of data scanned, the amount of time that the query took to
* process, and the type of statement that was run.
*
*
* @return Query execution statistics, such as the amount of data scanned, the amount of time that the query took to
* process, and the type of statement that was run.
*/
public QueryExecutionStatistics getStatistics() {
return this.statistics;
}
/**
*
* Query execution statistics, such as the amount of data scanned, the amount of time that the query took to
* process, and the type of statement that was run.
*
*
* @param statistics
* Query execution statistics, such as the amount of data scanned, the amount of time that the query took to
* process, and the type of statement that was run.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withStatistics(QueryExecutionStatistics statistics) {
setStatistics(statistics);
return this;
}
/**
*
* The name of the workgroup in which the query ran.
*
*
* @param workGroup
* The name of the workgroup in which the query ran.
*/
public void setWorkGroup(String workGroup) {
this.workGroup = workGroup;
}
/**
*
* The name of the workgroup in which the query ran.
*
*
* @return The name of the workgroup in which the query ran.
*/
public String getWorkGroup() {
return this.workGroup;
}
/**
*
* The name of the workgroup in which the query ran.
*
*
* @param workGroup
* The name of the workgroup in which the query ran.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withWorkGroup(String workGroup) {
setWorkGroup(workGroup);
return this;
}
/**
*
* The engine version that executed the query.
*
*
* @param engineVersion
* The engine version that executed the query.
*/
public void setEngineVersion(EngineVersion engineVersion) {
this.engineVersion = engineVersion;
}
/**
*
* The engine version that executed the query.
*
*
* @return The engine version that executed the query.
*/
public EngineVersion getEngineVersion() {
return this.engineVersion;
}
/**
*
* The engine version that executed the query.
*
*
* @param engineVersion
* The engine version that executed the query.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withEngineVersion(EngineVersion engineVersion) {
setEngineVersion(engineVersion);
return this;
}
/**
*
* A list of values for the parameters in a query. The values are applied sequentially to the parameters in the
* query in the order in which the parameters occur.
*
*
* @return A list of values for the parameters in a query. The values are applied sequentially to the parameters in
* the query in the order in which the parameters occur.
*/
public java.util.List getExecutionParameters() {
return executionParameters;
}
/**
*
* A list of values for the parameters in a query. The values are applied sequentially to the parameters in the
* query in the order in which the parameters occur.
*
*
* @param executionParameters
* A list of values for the parameters in a query. The values are applied sequentially to the parameters in
* the query in the order in which the parameters occur.
*/
public void setExecutionParameters(java.util.Collection executionParameters) {
if (executionParameters == null) {
this.executionParameters = null;
return;
}
this.executionParameters = new java.util.ArrayList(executionParameters);
}
/**
*
* A list of values for the parameters in a query. The values are applied sequentially to the parameters in the
* query in the order in which the parameters occur.
*
*
* NOTE: This method appends the values to the existing list (if any). Use
* {@link #setExecutionParameters(java.util.Collection)} or {@link #withExecutionParameters(java.util.Collection)}
* if you want to override the existing values.
*
*
* @param executionParameters
* A list of values for the parameters in a query. The values are applied sequentially to the parameters in
* the query in the order in which the parameters occur.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withExecutionParameters(String... executionParameters) {
if (this.executionParameters == null) {
setExecutionParameters(new java.util.ArrayList(executionParameters.length));
}
for (String ele : executionParameters) {
this.executionParameters.add(ele);
}
return this;
}
/**
*
* A list of values for the parameters in a query. The values are applied sequentially to the parameters in the
* query in the order in which the parameters occur.
*
*
* @param executionParameters
* A list of values for the parameters in a query. The values are applied sequentially to the parameters in
* the query in the order in which the parameters occur.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withExecutionParameters(java.util.Collection executionParameters) {
setExecutionParameters(executionParameters);
return this;
}
/**
*
* The kind of query statement that was run.
*
*
* @param substatementType
* The kind of query statement that was run.
*/
public void setSubstatementType(String substatementType) {
this.substatementType = substatementType;
}
/**
*
* The kind of query statement that was run.
*
*
* @return The kind of query statement that was run.
*/
public String getSubstatementType() {
return this.substatementType;
}
/**
*
* The kind of query statement that was run.
*
*
* @param substatementType
* The kind of query statement that was run.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public QueryExecution withSubstatementType(String substatementType) {
setSubstatementType(substatementType);
return this;
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getQueryExecutionId() != null)
sb.append("QueryExecutionId: ").append(getQueryExecutionId()).append(",");
if (getQuery() != null)
sb.append("Query: ").append(getQuery()).append(",");
if (getStatementType() != null)
sb.append("StatementType: ").append(getStatementType()).append(",");
if (getResultConfiguration() != null)
sb.append("ResultConfiguration: ").append(getResultConfiguration()).append(",");
if (getResultReuseConfiguration() != null)
sb.append("ResultReuseConfiguration: ").append(getResultReuseConfiguration()).append(",");
if (getQueryExecutionContext() != null)
sb.append("QueryExecutionContext: ").append(getQueryExecutionContext()).append(",");
if (getStatus() != null)
sb.append("Status: ").append(getStatus()).append(",");
if (getStatistics() != null)
sb.append("Statistics: ").append(getStatistics()).append(",");
if (getWorkGroup() != null)
sb.append("WorkGroup: ").append(getWorkGroup()).append(",");
if (getEngineVersion() != null)
sb.append("EngineVersion: ").append(getEngineVersion()).append(",");
if (getExecutionParameters() != null)
sb.append("ExecutionParameters: ").append(getExecutionParameters()).append(",");
if (getSubstatementType() != null)
sb.append("SubstatementType: ").append(getSubstatementType());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof QueryExecution == false)
return false;
QueryExecution other = (QueryExecution) obj;
if (other.getQueryExecutionId() == null ^ this.getQueryExecutionId() == null)
return false;
if (other.getQueryExecutionId() != null && other.getQueryExecutionId().equals(this.getQueryExecutionId()) == false)
return false;
if (other.getQuery() == null ^ this.getQuery() == null)
return false;
if (other.getQuery() != null && other.getQuery().equals(this.getQuery()) == false)
return false;
if (other.getStatementType() == null ^ this.getStatementType() == null)
return false;
if (other.getStatementType() != null && other.getStatementType().equals(this.getStatementType()) == false)
return false;
if (other.getResultConfiguration() == null ^ this.getResultConfiguration() == null)
return false;
if (other.getResultConfiguration() != null && other.getResultConfiguration().equals(this.getResultConfiguration()) == false)
return false;
if (other.getResultReuseConfiguration() == null ^ this.getResultReuseConfiguration() == null)
return false;
if (other.getResultReuseConfiguration() != null && other.getResultReuseConfiguration().equals(this.getResultReuseConfiguration()) == false)
return false;
if (other.getQueryExecutionContext() == null ^ this.getQueryExecutionContext() == null)
return false;
if (other.getQueryExecutionContext() != null && other.getQueryExecutionContext().equals(this.getQueryExecutionContext()) == false)
return false;
if (other.getStatus() == null ^ this.getStatus() == null)
return false;
if (other.getStatus() != null && other.getStatus().equals(this.getStatus()) == false)
return false;
if (other.getStatistics() == null ^ this.getStatistics() == null)
return false;
if (other.getStatistics() != null && other.getStatistics().equals(this.getStatistics()) == false)
return false;
if (other.getWorkGroup() == null ^ this.getWorkGroup() == null)
return false;
if (other.getWorkGroup() != null && other.getWorkGroup().equals(this.getWorkGroup()) == false)
return false;
if (other.getEngineVersion() == null ^ this.getEngineVersion() == null)
return false;
if (other.getEngineVersion() != null && other.getEngineVersion().equals(this.getEngineVersion()) == false)
return false;
if (other.getExecutionParameters() == null ^ this.getExecutionParameters() == null)
return false;
if (other.getExecutionParameters() != null && other.getExecutionParameters().equals(this.getExecutionParameters()) == false)
return false;
if (other.getSubstatementType() == null ^ this.getSubstatementType() == null)
return false;
if (other.getSubstatementType() != null && other.getSubstatementType().equals(this.getSubstatementType()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getQueryExecutionId() == null) ? 0 : getQueryExecutionId().hashCode());
hashCode = prime * hashCode + ((getQuery() == null) ? 0 : getQuery().hashCode());
hashCode = prime * hashCode + ((getStatementType() == null) ? 0 : getStatementType().hashCode());
hashCode = prime * hashCode + ((getResultConfiguration() == null) ? 0 : getResultConfiguration().hashCode());
hashCode = prime * hashCode + ((getResultReuseConfiguration() == null) ? 0 : getResultReuseConfiguration().hashCode());
hashCode = prime * hashCode + ((getQueryExecutionContext() == null) ? 0 : getQueryExecutionContext().hashCode());
hashCode = prime * hashCode + ((getStatus() == null) ? 0 : getStatus().hashCode());
hashCode = prime * hashCode + ((getStatistics() == null) ? 0 : getStatistics().hashCode());
hashCode = prime * hashCode + ((getWorkGroup() == null) ? 0 : getWorkGroup().hashCode());
hashCode = prime * hashCode + ((getEngineVersion() == null) ? 0 : getEngineVersion().hashCode());
hashCode = prime * hashCode + ((getExecutionParameters() == null) ? 0 : getExecutionParameters().hashCode());
hashCode = prime * hashCode + ((getSubstatementType() == null) ? 0 : getSubstatementType().hashCode());
return hashCode;
}
@Override
public QueryExecution clone() {
try {
return (QueryExecution) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
@com.amazonaws.annotation.SdkInternalApi
@Override
public void marshall(ProtocolMarshaller protocolMarshaller) {
com.amazonaws.services.athena.model.transform.QueryExecutionMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}