All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.tinygroup.tinysqldsl.expression.AnalyticExpression Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (c) 1997-2013, www.tinygroup.org ([email protected]).
 * 

* Licensed under the GPL, Version 3.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.gnu.org/licenses/gpl.html *

* 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. */ package org.tinygroup.tinysqldsl.expression; import org.tinygroup.tinysqldsl.base.StatementSqlBuilder; import org.tinygroup.tinysqldsl.expression.relational.ExpressionList; import org.tinygroup.tinysqldsl.select.OrderByElement; import org.tinygroup.tinysqldsl.util.DslUtil; import java.util.List; /** * Analytic function. The name of the function is variable but the parameters * following the special analytic function path. e.g. row_number() over (order * by test). Additional there can be an expression for an analytical aggregate * like sum(col) or the "all collumns" wildcard like count(*). * */ public class AnalyticExpression implements Expression { // private List partitionByColumns; private ExpressionList partitionExpressionList; private List orderByElements; private String name; private Expression expression; private Expression offset; private Expression defaultValue; private boolean allColumns = false; private WindowElement windowElement; public List getOrderByElements() { return orderByElements; } public ExpressionList getPartitionExpressionList() { return partitionExpressionList; } public void setPartitionExpressionList( ExpressionList partitionExpressionList) { this.partitionExpressionList = partitionExpressionList; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Expression getExpression() { return expression; } public void setExpression(Expression expression) { this.expression = expression; } public Expression getOffset() { return offset; } public void setOffset(Expression offset) { this.offset = offset; } public Expression getDefaultValue() { return defaultValue; } public void setDefaultValue(Expression defaultValue) { this.defaultValue = defaultValue; } public WindowElement getWindowElement() { return windowElement; } public void setWindowElement(WindowElement windowElement) { this.windowElement = windowElement; } @Override public String toString() { StringBuilder b = new StringBuilder(); b.append(name).append("("); if (expression != null) { b.append(expression.toString()); if (offset != null) { b.append(", ").append(offset.toString()); if (defaultValue != null) { b.append(", ").append(defaultValue.toString()); } } } else if (isAllColumns()) { b.append("*"); } b.append(") OVER ("); toStringPartitionBy(b); toStringOrderByElements(b); b.append(")"); return b.toString(); } public boolean isAllColumns() { return allColumns; } public void setAllColumns(boolean allColumns) { this.allColumns = allColumns; } private void toStringPartitionBy(StringBuilder b) { if (partitionExpressionList != null && !partitionExpressionList.getExpressions().isEmpty()) { b.append("PARTITION BY "); b.append(DslUtil.getStringList( partitionExpressionList.getExpressions(), true, false)); b.append(" "); } } private void toStringOrderByElements(StringBuilder b) { if (orderByElements != null && !orderByElements.isEmpty()) { b.append("ORDER BY "); for (int i = 0; i < orderByElements.size(); i++) { if (i > 0) { b.append(", "); } b.append(orderByElements.get(i).toString()); } if (windowElement != null) { b.append(' '); b.append(windowElement); } } } public void builderExpression(StatementSqlBuilder builder) { builder.appendSql(toString()); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy