Skip to content

Commit

Permalink
[NSE-400] Fix the bug for negative decimal data (oap-project#686)
Browse files Browse the repository at this point in the history
* Fix the bug for positive decimal data

* Fix format

* Fix the unit test for 'SPARK-22348: table cache should do partition batch pruning (whole-stage-codegen on)'
  • Loading branch information
haojinIntel authored and zhouyuan committed Jan 10, 2022
1 parent 0ba160b commit 5b09e24
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,8 @@ package org.apache.spark.sql.execution.columnar
import java.nio.charset.StandardCharsets
import java.sql.{Date, Timestamp}

import com.intel.oap.execution.ColumnarConditionProjectExec
import com.intel.oap.sql.execution.RowToArrowColumnarExec
import com.intel.oap.execution.{ArrowRowToColumnarExec, ColumnarConditionProjectExec}

import org.apache.spark.rdd.RDD
import org.apache.spark.sql.{DataFrame, QueryTest, Row}
import org.apache.spark.sql.catalyst.InternalRow
Expand Down Expand Up @@ -506,7 +506,7 @@ class InMemoryColumnarQuerySuite extends QueryTest with SharedSparkSession {
val df2 = df1.where("y = 3")

val planBeforeFilter = df2.queryExecution.executedPlan.collect {
case ColumnarConditionProjectExec(_, _, c: RowToArrowColumnarExec) => c.child
case ColumnarConditionProjectExec(_, _, c: ArrowRowToColumnarExec) => c.child
case FilterExec(_, c: ColumnarToRowExec) => c.child
case WholeStageCodegenExec(FilterExec(_, ColumnarToRowExec(i: InputAdapter))) => i.child
}
Expand Down
10 changes: 10 additions & 0 deletions native-sql-engine/cpp/src/operators/row_to_columnar_converter.cc
Original file line number Diff line number Diff line change
Expand Up @@ -393,6 +393,11 @@ arrow::Status CreateArrayData(std::shared_ptr<arrow::Schema> schema, int64_t num
for (int k = length - 1; k >= 0; k--) {
bytesValue2[length - 1 - k] = bytesValue[k];
}
if (int8_t(bytesValue[0]) < 0) {
for (int k = length; k < 16; k++) {
bytesValue2[k] = 255;
}
}
arrow::Decimal128 value =
arrow::Decimal128(arrow::BasicDecimal128(bytesValue2));
array_data[position] = value;
Expand Down Expand Up @@ -950,6 +955,11 @@ arrow::Status CreateArrayData(std::shared_ptr<arrow::Schema> schema, int64_t num
for (int k = elementLength - 1; k >= 0; k--) {
bytesValue2[elementLength - 1 - k] = bytesValue[k];
}
if (int8_t(bytesValue[0]) < 0) {
for (int k = elementLength; k < 16; k++) {
bytesValue2[k] = 255;
}
}
arrow::Decimal128 value =
arrow::Decimal128(arrow::BasicDecimal128(bytesValue2));
RETURN_NOT_OK(child_builder.Append(value));
Expand Down

0 comments on commit 5b09e24

Please sign in to comment.