From 5dc5c6a31a3e785bcf443245af206f38b2f06b8c Mon Sep 17 00:00:00 2001 From: Andrei Stefan Date: Wed, 27 Feb 2019 09:48:10 +0200 Subject: [PATCH] SQL: change the default precision for CURRENT_TIMESTAMP function (#39391) (cherry picked from commit dbb93310b083226c96e4bde3eef0079eb01cbca9) --- docs/reference/sql/functions/date-time.asciidoc | 3 ++- .../function/scalar/datetime/CurrentDateTime.java | 2 +- .../scalar/datetime/CurrentDateTimeTests.java | 13 +++++++++++++ 3 files changed, 16 insertions(+), 2 deletions(-) diff --git a/docs/reference/sql/functions/date-time.asciidoc b/docs/reference/sql/functions/date-time.asciidoc index 0ee0d39f30a9a..de173f3af06f1 100644 --- a/docs/reference/sql/functions/date-time.asciidoc +++ b/docs/reference/sql/functions/date-time.asciidoc @@ -153,7 +153,8 @@ CURRENT_TIMESTAMP(precision <1>) Returns the date/time when the current query reached the server. As a function, `CURRENT_TIMESTAMP()` accepts _precision_ as an optional -parameter for rounding the second fractional digits (nanoseconds). +parameter for rounding the second fractional digits (nanoseconds). The default _precision_ is 3, +meaning a milliseconds precision current date/time will be returned. This method always returns the same value for its every occurrence within the same query. diff --git a/x-pack/plugin/sql/src/main/java/org/elasticsearch/xpack/sql/expression/function/scalar/datetime/CurrentDateTime.java b/x-pack/plugin/sql/src/main/java/org/elasticsearch/xpack/sql/expression/function/scalar/datetime/CurrentDateTime.java index 8224ef090b78c..6ca9607d893c1 100644 --- a/x-pack/plugin/sql/src/main/java/org/elasticsearch/xpack/sql/expression/function/scalar/datetime/CurrentDateTime.java +++ b/x-pack/plugin/sql/src/main/java/org/elasticsearch/xpack/sql/expression/function/scalar/datetime/CurrentDateTime.java @@ -34,7 +34,7 @@ protected NodeInfo info() { } static ZonedDateTime nanoPrecision(ZonedDateTime zdt, Expression precisionExpression) { - int precision = precisionExpression != null ? Foldables.intValueOf(precisionExpression) : 0; + int precision = precisionExpression != null ? Foldables.intValueOf(precisionExpression) : 3; int nano = zdt.getNano(); if (precision >= 0 && precision < 10) { // remove the remainder diff --git a/x-pack/plugin/sql/src/test/java/org/elasticsearch/xpack/sql/expression/function/scalar/datetime/CurrentDateTimeTests.java b/x-pack/plugin/sql/src/test/java/org/elasticsearch/xpack/sql/expression/function/scalar/datetime/CurrentDateTimeTests.java index d9cb681d03fcb..405d4805410e5 100644 --- a/x-pack/plugin/sql/src/test/java/org/elasticsearch/xpack/sql/expression/function/scalar/datetime/CurrentDateTimeTests.java +++ b/x-pack/plugin/sql/src/test/java/org/elasticsearch/xpack/sql/expression/function/scalar/datetime/CurrentDateTimeTests.java @@ -9,10 +9,12 @@ import org.elasticsearch.xpack.sql.TestUtils; import org.elasticsearch.xpack.sql.expression.Expression; import org.elasticsearch.xpack.sql.expression.Literal; +import org.elasticsearch.xpack.sql.session.Configuration; import org.elasticsearch.xpack.sql.tree.AbstractNodeTestCase; import java.time.ZoneId; import java.time.ZonedDateTime; +import java.time.temporal.ChronoField; import java.util.Objects; import static org.elasticsearch.xpack.sql.tree.Source.EMPTY; @@ -62,4 +64,15 @@ public void testNanoPrecision() { assertEquals(123_456_780, CurrentDateTime.nanoPrecision(zdt, Literal.of(EMPTY, 8)).getNano()); assertEquals(123_456_789, CurrentDateTime.nanoPrecision(zdt, Literal.of(EMPTY, 9)).getNano()); } + + public void testDefaultPrecision() { + Configuration configuration = TestUtils.randomConfiguration(); + // null precision means default precision + CurrentDateTime cdt = new CurrentDateTime(EMPTY, null, configuration); + ZonedDateTime now = configuration.now(); + assertEquals(now.get(ChronoField.MILLI_OF_SECOND), ((ZonedDateTime) cdt.fold()).get(ChronoField.MILLI_OF_SECOND)); + + ZonedDateTime zdt = ZonedDateTime.parse("2019-02-26T12:34:56.123456789Z"); + assertEquals(123_000_000, CurrentDateTime.nanoPrecision(zdt, null).getNano()); + } }