org.apache.kylin.metadata.model.FunctionDesc Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*/
package org.apache.kylin.metadata.model;
import java.util.Collection;
import org.apache.kylin.measure.MeasureType;
import org.apache.kylin.measure.MeasureTypeFactory;
import org.apache.kylin.measure.basic.BasicMeasureType;
import org.apache.kylin.metadata.datatype.DataType;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.JsonAutoDetect.Visibility;
import com.fasterxml.jackson.annotation.JsonProperty;
/**
* Created with IntelliJ IDEA. User: lukhan Date: 9/26/13 Time: 1:30 PM To
* change this template use File | Settings | File Templates.
*/
@JsonAutoDetect(fieldVisibility = Visibility.NONE, getterVisibility = Visibility.NONE, isGetterVisibility = Visibility.NONE, setterVisibility = Visibility.NONE)
public class FunctionDesc {
public static final String FUNC_SUM = "SUM";
public static final String FUNC_MIN = "MIN";
public static final String FUNC_MAX = "MAX";
public static final String FUNC_COUNT = "COUNT";
public static final String FUNC_COUNT_DISTINCT = "COUNT_DISTINCT";
public static final String PARAMTER_TYPE_CONSTANT = "constant";
public static final String PARAMETER_TYPE_COLUMN = "column";
@JsonProperty("expression")
private String expression;
@JsonProperty("parameter")
private ParameterDesc parameter;
@JsonProperty("returntype")
private String returnType;
private DataType returnDataType;
private MeasureType> measureType;
private boolean isDimensionAsMetric = false;
public String getRewriteFieldName() {
if (isSum()) {
return getParameter().getValue();
} else if (isCount()) {
return "COUNT__"; // ignores parameter, count(*), count(1),
// count(col) are all the same
} else {
return getFullExpression().replaceAll("[(), ]", "_");
}
}
public MeasureType> getMeasureType() {
if (isDimensionAsMetric)
return null;
if (measureType == null) {
measureType = MeasureTypeFactory.create(getExpression(), getReturnDataType());
}
return measureType;
}
public boolean needRewrite() {
if (isDimensionAsMetric)
return false;
return getMeasureType().needRewrite();
}
public boolean isMin() {
return FUNC_MIN.equalsIgnoreCase(expression);
}
public boolean isMax() {
return FUNC_MAX.equalsIgnoreCase(expression);
}
public boolean isSum() {
return FUNC_SUM.equalsIgnoreCase(expression);
}
public boolean isCount() {
return FUNC_COUNT.equalsIgnoreCase(expression);
}
/**
* Get Full Expression such as sum(amount), count(1), count(*)...
*/
public String getFullExpression() {
StringBuilder sb = new StringBuilder(expression);
sb.append("(");
if (parameter != null) {
sb.append(parameter.getValue());
}
sb.append(")");
return sb.toString();
}
public boolean isDimensionAsMetric() {
return isDimensionAsMetric;
}
public void setDimensionAsMetric(boolean isDimensionAsMetric) {
this.isDimensionAsMetric = isDimensionAsMetric;
}
public String getExpression() {
return expression;
}
public void setExpression(String expression) {
this.expression = expression;
}
public ParameterDesc getParameter() {
return parameter;
}
public void setParameter(ParameterDesc parameter) {
this.parameter = parameter;
}
public DataType getRewriteFieldType() {
if (isSum() || isMax() || isMin())
return parameter.getColRefs().get(0).getType();
else if (getMeasureType() instanceof BasicMeasureType)
return returnDataType;
else
return DataType.ANY;
}
public String getReturnType() {
return returnType;
}
public DataType getReturnDataType() {
return returnDataType;
}
public int getParameterCount() {
int count = 0;
for (ParameterDesc p = parameter; p != null; p = p.getNextParameter()) {
count++;
}
return count;
}
public void setReturnType(String returnType) {
this.returnType = returnType;
this.initReturnDataType();
}
// Jackson does not provide object post-processing currently
public void initReturnDataType() {
this.returnDataType = DataType.getInstance(returnType);
}
public TblColRef selectTblColRef(Collection metricColumns, String factTableName) {
if (this.isCount())
return null; // count is not about any column but the whole row
ParameterDesc parameter = this.getParameter();
if (parameter == null)
return null;
String columnName = parameter.getValue();
for (TblColRef col : metricColumns) {
if (col.isSameAs(factTableName, columnName)) {
return col;
}
}
return null;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((expression == null) ? 0 : expression.hashCode());
result = prime * result + ((isCount() || parameter == null) ? 0 : parameter.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
FunctionDesc other = (FunctionDesc) obj;
if (expression == null) {
if (other.expression != null)
return false;
} else if (!expression.equals(other.expression))
return false;
// NOTE: don't check the parameter of count()
if (isCount() == false) {
if (parameter == null) {
if (other.parameter != null)
return false;
} else if (!parameter.equals(other.parameter))
return false;
}
return true;
}
@Override
public String toString() {
return "FunctionDesc [expression=" + expression + ", parameter=" + parameter + ", returnType=" + returnType + "]";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy