net.hasor.db.jsqlparser.expression.Function Maven / Gradle / Ivy
The newest version!
/*-
* #%L
* JSQLParser library
* %%
* Copyright (C) 2004 - 2019 JSQLParser
* %%
* Dual licensed under GNU LGPL 2.1 or Apache License 2.0
* #L%
*/
package net.sf.jsqlparser.expression;
import net.sf.jsqlparser.expression.operators.relational.ExpressionList;
import net.sf.jsqlparser.expression.operators.relational.NamedExpressionList;
import net.sf.jsqlparser.parser.ASTNodeAccessImpl;
/**
* A function as MAX,COUNT...
*/
public class Function extends ASTNodeAccessImpl implements Expression {
private String name;
private ExpressionList parameters;
private NamedExpressionList namedParameters;
private boolean allColumns = false;
private boolean distinct = false;
private boolean isEscaped = false;
private Expression attribute;
private String attributeName;
private KeepExpression keep = null;
private boolean ignoreNulls = false;
@Override
public void accept(ExpressionVisitor expressionVisitor) {
expressionVisitor.visit(this);
}
public String getName() {
return name;
}
public void setName(String string) {
name = string;
}
public boolean isAllColumns() {
return allColumns;
}
public void setAllColumns(boolean b) {
allColumns = b;
}
public boolean isIgnoreNulls() {
return ignoreNulls;
}
/**
* This is at the moment only necessary for AnalyticExpression initialization and not for normal
* functions. Therefore there is no deparsing for it for normal functions.
*
* @param ignoreNulls
*/
public void setIgnoreNulls(boolean ignoreNulls) {
this.ignoreNulls = ignoreNulls;
}
/**
* true if the function is "distinct"
*
* @return true if the function is "distinct"
*/
public boolean isDistinct() {
return distinct;
}
public void setDistinct(boolean b) {
distinct = b;
}
/**
* The list of parameters of the function (if any, else null) If the parameter is "*",
* allColumns is set to true
*
* @return the list of parameters of the function (if any, else null)
*/
public ExpressionList getParameters() {
return parameters;
}
public void setParameters(ExpressionList list) {
parameters = list;
}
/**
* the parameters might be named parameters, e.g. substring('foobar' from 2 for 3)
*
* @return the list of named parameters of the function (if any, else null)
*/
public NamedExpressionList getNamedParameters() {
return namedParameters;
}
public void setNamedParameters(NamedExpressionList list) {
namedParameters = list;
}
/**
* Return true if it's in the form "{fn function_body() }"
*
* @return true if it's java-escaped
*/
public boolean isEscaped() {
return isEscaped;
}
public void setEscaped(boolean isEscaped) {
this.isEscaped = isEscaped;
}
public Expression getAttribute() {
return attribute;
}
public void setAttribute(Expression attribute) {
this.attribute = attribute;
}
public String getAttributeName() {
return attributeName;
}
public void setAttributeName(String attributeName) {
this.attributeName = attributeName;
}
public KeepExpression getKeep() {
return keep;
}
public void setKeep(KeepExpression keep) {
this.keep = keep;
}
@Override
public String toString() {
String params;
if (parameters != null || namedParameters != null) {
if (parameters != null) {
params = parameters.toString();
if (isDistinct()) {
params = params.replaceFirst("\\(", "(DISTINCT ");
} else if (isAllColumns()) {
params = params.replaceFirst("\\(", "(ALL ");
}
} else {
params = namedParameters.toString();
}
} else if (isAllColumns()) {
params = "(*)";
} else {
params = "()";
}
String ans = name + "" + params + "";
if (attribute != null) {
ans += "." + attribute.toString();
} else if (attributeName != null) {
ans += "." + attributeName;
}
if (keep != null) {
ans += " " + keep.toString();
}
if (isEscaped) {
ans = "{fn " + ans + "}";
}
return ans;
}
}