diff --git a/native-sql-engine/core/src/main/scala/com/intel/oap/expression/CodeGeneration.scala b/native-sql-engine/core/src/main/scala/com/intel/oap/expression/CodeGeneration.scala index d68a40e3c..36f42987b 100644 --- a/native-sql-engine/core/src/main/scala/com/intel/oap/expression/CodeGeneration.scala +++ b/native-sql-engine/core/src/main/scala/com/intel/oap/expression/CodeGeneration.scala @@ -32,7 +32,19 @@ object CodeGeneration { def getResultType(left: ArrowType, right: ArrowType): ArrowType = { //TODO(): remove this API - left + // Use left type except that left is int16. If both right & left are int16, + // int32 will be used. + left match { + case intLeft: ArrowType.Int if (intLeft.getBitWidth == 16) => + right match { + case intRight: ArrowType.Int if (intRight.getBitWidth == 16) => + new ArrowType.Int(32, true) + case _ => + right + } + case _ => + left + } } def getResultType(dataType: DataType): ArrowType = { @@ -81,6 +93,8 @@ object CodeGeneration { dataType match { case t: ArrowType.FloatingPoint => s"castFLOAT${4 * dataType.asInstanceOf[ArrowType.FloatingPoint].getPrecision().getFlatbufID()}" + case i: ArrowType.Int if i.getBitWidth == 32 => + "castINT" case _ => throw new UnsupportedOperationException(s"getCastFuncName(${dataType}) is not supported.") } diff --git a/native-sql-engine/core/src/main/scala/com/intel/oap/expression/ColumnarLiterals.scala b/native-sql-engine/core/src/main/scala/com/intel/oap/expression/ColumnarLiterals.scala index f1f40fd45..5e5070823 100644 --- a/native-sql-engine/core/src/main/scala/com/intel/oap/expression/ColumnarLiterals.scala +++ b/native-sql-engine/core/src/main/scala/com/intel/oap/expression/ColumnarLiterals.scala @@ -42,7 +42,7 @@ class ColumnarLiteral(lit: Literal) def buildCheck(): ArrowType = { val supportedTypes = - List(StringType, IntegerType, LongType, DoubleType, FloatType, DateType, + List(StringType, ShortType, IntegerType, LongType, DoubleType, FloatType, DateType, BooleanType, CalendarIntervalType, BinaryType, TimestampType) if (supportedTypes.indexOf(dataType) == -1 && !dataType.isInstanceOf[DecimalType]) { // Decimal is supported in ColumnarLiteral @@ -75,6 +75,8 @@ class ColumnarLiteral(lit: Literal) throw new UnsupportedOperationException( s"can't support CalendarIntervalType with microseconds yet") } + case ShortType => + new ArrowType.Int(32, true) case _ => CodeGeneration.getResultType(dataType) } @@ -97,12 +99,13 @@ class ColumnarLiteral(lit: Literal) case _ => (TreeBuilder.makeLiteral(value.asInstanceOf[Integer]), resultType) } - case t: ShortType => + case _: ShortType => value match { case null => (TreeBuilder.makeNull(resultType), resultType) case _ => - (TreeBuilder.makeLiteral(value.asInstanceOf[Integer]), resultType) + (TreeBuilder.makeLiteral(new Integer( + value.asInstanceOf[java.lang.Short].toInt)), resultType) } case t: LongType => value match {