package com.taobao.tddl.executor.function.scalar; import com.taobao.tddl.executor.function.ScalarFunction; import com.taobao.tddl.optimizer.core.datatype.DataType; import com.taobao.tddl.optimizer.core.datatype.DataTypeUtil; import com.taobao.tddl.optimizer.core.expression.ISelectable; public class Multiply extends ScalarFunction { @Override public void compute(Object[] args) { this.result = computeInner(args); } @Override public DataType getReturnType() { Object[] args = function.getArgs().toArray(); DataType type = null; if (args[0] instanceof ISelectable) { type = ((ISelectable) args[0]).getDataType(); } if (type == null) { type = DataTypeUtil.getTypeOfObject(args[0]); } if (type == DataType.IntegerType || type == DataType.ShortType) { return DataType.LongType; } else { return type; } } private Object computeInner(Object[] args) { DataType type = this.getReturnType(); return type.getCalculator().multiply(args[0], args[1]); } }