aboutsummaryrefslogtreecommitdiff
path: root/sql/core/src
diff options
context:
space:
mode:
authorDaoyuan Wang <daoyuan.wang@intel.com>2015-05-06 10:05:10 -0700
committerReynold Xin <rxin@databricks.com>2015-05-06 10:05:10 -0700
commit150f671c286c57deaf37ab1d8f837d68b5be82a0 (patch)
treebed000809095b8f46c2ab0cc0dd8defb4195fbd4 /sql/core/src
parent322e7e7f689947aef29909572ee0c0e110ea23b8 (diff)
downloadspark-150f671c286c57deaf37ab1d8f837d68b5be82a0.tar.gz
spark-150f671c286c57deaf37ab1d8f837d68b5be82a0.tar.bz2
spark-150f671c286c57deaf37ab1d8f837d68b5be82a0.zip
[SPARK-5456] [SQL] fix decimal compare for jdbc rdd
Author: Daoyuan Wang <daoyuan.wang@intel.com> Closes #5803 from adrian-wang/decimalcompare and squashes the following commits: aef0e96 [Daoyuan Wang] add null handle ec455b9 [Daoyuan Wang] fix decimal compare for jdbc rdd
Diffstat (limited to 'sql/core/src')
-rw-r--r--sql/core/src/main/scala/org/apache/spark/sql/jdbc/JDBCRDD.scala8
-rw-r--r--sql/core/src/test/scala/org/apache/spark/sql/jdbc/JDBCSuite.scala5
2 files changed, 11 insertions, 2 deletions
diff --git a/sql/core/src/main/scala/org/apache/spark/sql/jdbc/JDBCRDD.scala b/sql/core/src/main/scala/org/apache/spark/sql/jdbc/JDBCRDD.scala
index 2f6ba48dbc..325a326e2b 100644
--- a/sql/core/src/main/scala/org/apache/spark/sql/jdbc/JDBCRDD.scala
+++ b/sql/core/src/main/scala/org/apache/spark/sql/jdbc/JDBCRDD.scala
@@ -363,7 +363,13 @@ private[sql] class JDBCRDD(
case BooleanConversion => mutableRow.setBoolean(i, rs.getBoolean(pos))
case DateConversion =>
mutableRow.update(i, DateUtils.fromJavaDate(rs.getDate(pos)))
- case DecimalConversion => mutableRow.update(i, rs.getBigDecimal(pos))
+ case DecimalConversion =>
+ val decimalVal = rs.getBigDecimal(pos)
+ if (decimalVal == null) {
+ mutableRow.update(i, null)
+ } else {
+ mutableRow.update(i, Decimal(decimalVal))
+ }
case DoubleConversion => mutableRow.setDouble(i, rs.getDouble(pos))
case FloatConversion => mutableRow.setFloat(i, rs.getFloat(pos))
case IntegerConversion => mutableRow.setInt(i, rs.getInt(pos))
diff --git a/sql/core/src/test/scala/org/apache/spark/sql/jdbc/JDBCSuite.scala b/sql/core/src/test/scala/org/apache/spark/sql/jdbc/JDBCSuite.scala
index b165ab2b1d..3ec17d37c0 100644
--- a/sql/core/src/test/scala/org/apache/spark/sql/jdbc/JDBCSuite.scala
+++ b/sql/core/src/test/scala/org/apache/spark/sql/jdbc/JDBCSuite.scala
@@ -271,8 +271,11 @@ class JDBCSuite extends FunSuite with BeforeAndAfter {
assert(rows(0).getDouble(0) === 1.00000000000000022) // Yes, I meant ==.
assert(rows(0).getDouble(1) === 1.00000011920928955) // Yes, I meant ==.
assert(rows(0).getAs[BigDecimal](2)
- .equals(new BigDecimal("123456789012345.54321543215432100000")))
+ .equals(new BigDecimal("123456789012345.54321543215432100000")))
assert(rows(0).schema.fields(2).dataType === DecimalType(40, 20))
+ val compareDecimal = sql("SELECT C FROM flttypes where C > C - 1").collect()
+ assert(compareDecimal(0).getAs[BigDecimal](0)
+ .equals(new BigDecimal("123456789012345.54321543215432100000")))
}
test("SQL query as table name") {