
com.google.api.ads.admanager.axis.v202102.Statement Maven / Gradle / Ivy
// Copyright 2021 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License 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.
/**
* Statement.java
*
* This file was auto-generated from WSDL
* by the Apache Axis 1.4 Mar 02, 2009 (07:08:06 PST) WSDL2Java emitter.
*/
package com.google.api.ads.admanager.axis.v202102;
/**
* Captures the {@code WHERE}, {@code ORDER BY} and {@code LIMIT}
* clauses of a
* PQL query. Statements are typically used to retrieve objects
* of a predefined
* domain type, which makes SELECT clause unnecessary.
*
* An example query text might be {@code "WHERE status =
* 'ACTIVE' ORDER BY id
* LIMIT 30"}.
*
*
* Statements support bind variables. These are substitutes
* for literals
* and can be thought of as input parameters to a PQL query.
*
*
* An example of such a query might be {@code "WHERE id =
* :idValue"}.
*
*
* Statements also support use of the LIKE keyword. This
* provides wildcard string matching.
*
*
* An example of such a query might be {@code "WHERE name
* LIKE '%searchString%'"}.
*
* The value for the variable idValue must then be set with
* an object of type
* {@link Value}, e.g., {@link NumberValue}, {@link TextValue}
* or
* {@link BooleanValue}.
*/
public class Statement implements java.io.Serializable {
/* Holds the query in PQL syntax. The syntax is:
* [WHERE {[AND | OR] ...}]
* [ORDER BY [ASC | DESC]]
* [LIMIT {[,] } | { OFFSET
* }]
*
*
*
* := {< | <= | > | >= | = | != }
*
*
* := {< | <= | > | >= | = | != }
* := IN
* := IS NULL
* := LIKE
* := :
*
*/
private java.lang.String query;
/* Holds keys and values for bind variables and their values.
* The key is the
* name of the bind variable. The value is the literal
* value of the variable.
*
* In the example {@code "WHERE status = :bindStatus
* ORDER BY id LIMIT 30"},
* the bind variable, represented by {@code :bindStatus}
* is named {@code
* bindStatus}, which would also be the parameter map
* key. The bind variable's
* value would be represented by a parameter map value
* of type
* {@link TextValue}. The final result, for example,
* would be an entry of
* {@code "bindStatus" => StringParam("ACTIVE")}.
*
*/
private com.google.api.ads.admanager.axis.v202102.String_ValueMapEntry[] values;
public Statement() {
}
public Statement(
java.lang.String query,
com.google.api.ads.admanager.axis.v202102.String_ValueMapEntry[] values) {
this.query = query;
this.values = values;
}
@Override
public String toString() {
return com.google.common.base.MoreObjects.toStringHelper(this.getClass())
.omitNullValues()
.add("query", getQuery())
.add("values", getValues())
.toString();
}
/**
* Gets the query value for this Statement.
*
* @return query * Holds the query in PQL syntax. The syntax is:
* [WHERE {[AND | OR] ...}]
* [ORDER BY [ASC | DESC]]
* [LIMIT {[,] } | { OFFSET
* }]
*
*
*
* := {< | <= | > | >= | = | != }
*
*
* := {< | <= | > | >= | = | != }
* := IN
* := IS NULL
* := LIKE
* := :
*
*/
public java.lang.String getQuery() {
return query;
}
/**
* Sets the query value for this Statement.
*
* @param query * Holds the query in PQL syntax. The syntax is:
* [WHERE {[AND | OR] ...}]
* [ORDER BY [ASC | DESC]]
* [LIMIT {[,] } | { OFFSET
* }]
*
*
*
* := {< | <= | > | >= | = | != }
*
*
* := {< | <= | > | >= | = | != }
* := IN
* := IS NULL
* := LIKE
* := :
*
*/
public void setQuery(java.lang.String query) {
this.query = query;
}
/**
* Gets the values value for this Statement.
*
* @return values * Holds keys and values for bind variables and their values.
* The key is the
* name of the bind variable. The value is the literal
* value of the variable.
*
* In the example {@code "WHERE status = :bindStatus
* ORDER BY id LIMIT 30"},
* the bind variable, represented by {@code :bindStatus}
* is named {@code
* bindStatus}, which would also be the parameter map
* key. The bind variable's
* value would be represented by a parameter map value
* of type
* {@link TextValue}. The final result, for example,
* would be an entry of
* {@code "bindStatus" => StringParam("ACTIVE")}.
*
*/
public com.google.api.ads.admanager.axis.v202102.String_ValueMapEntry[] getValues() {
return values;
}
/**
* Sets the values value for this Statement.
*
* @param values * Holds keys and values for bind variables and their values.
* The key is the
* name of the bind variable. The value is the literal
* value of the variable.
*
* In the example {@code "WHERE status = :bindStatus
* ORDER BY id LIMIT 30"},
* the bind variable, represented by {@code :bindStatus}
* is named {@code
* bindStatus}, which would also be the parameter map
* key. The bind variable's
* value would be represented by a parameter map value
* of type
* {@link TextValue}. The final result, for example,
* would be an entry of
* {@code "bindStatus" => StringParam("ACTIVE")}.
*
*/
public void setValues(com.google.api.ads.admanager.axis.v202102.String_ValueMapEntry[] values) {
this.values = values;
}
public com.google.api.ads.admanager.axis.v202102.String_ValueMapEntry getValues(int i) {
return this.values[i];
}
public void setValues(int i, com.google.api.ads.admanager.axis.v202102.String_ValueMapEntry _value) {
this.values[i] = _value;
}
private java.lang.Object __equalsCalc = null;
public synchronized boolean equals(java.lang.Object obj) {
if (!(obj instanceof Statement)) return false;
Statement other = (Statement) obj;
if (obj == null) return false;
if (this == obj) return true;
if (__equalsCalc != null) {
return (__equalsCalc == obj);
}
__equalsCalc = obj;
boolean _equals;
_equals = true &&
((this.query==null && other.getQuery()==null) ||
(this.query!=null &&
this.query.equals(other.getQuery()))) &&
((this.values==null && other.getValues()==null) ||
(this.values!=null &&
java.util.Arrays.equals(this.values, other.getValues())));
__equalsCalc = null;
return _equals;
}
private boolean __hashCodeCalc = false;
public synchronized int hashCode() {
if (__hashCodeCalc) {
return 0;
}
__hashCodeCalc = true;
int _hashCode = 1;
if (getQuery() != null) {
_hashCode += getQuery().hashCode();
}
if (getValues() != null) {
for (int i=0;
i