Skip to content

Commit

Permalink
Convert date_nanos example script to runtime field (backport of elast…
Browse files Browse the repository at this point in the history
…ic#71351)

Runtime fields are much more flexible than script_fields because you
can filter and aggregate on them so we hope folks use them! This
converts the example of using a `date_nanos` field in a script to a
runtime field so folks get used to seeing them and hopefully using them.

While I was editing this I took the opportunity to replace the script
with a real-ish example. Scripts that just load the field value are nice
and short but I hope no one uses them in real life because they just add
overhead when compared to accessing the field directly. So I made the
script do something.

Relates to elastic#69291

Co-authored-by: Adam Locke <[email protected]>
  • Loading branch information
nik9000 and Adam Locke committed Apr 12, 2021
1 parent ca8379b commit 247850f
Showing 1 changed file with 69 additions and 29 deletions.
98 changes: 69 additions & 29 deletions docs/reference/mapping/types/date_nanos.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -37,52 +37,92 @@ PUT my-index-000001?include_type_name=true
}
}
PUT my-index-000001/_doc/1
PUT my-index-000001/_bulk?refresh
{ "index" : { "_id" : "1" } }
{ "date": "2015-01-01" } <2>
PUT my-index-000001/_doc/2
{ "index" : { "_id" : "2" } }
{ "date": "2015-01-01T12:10:30.123456789Z" } <3>
PUT my-index-000001/_doc/3
{ "date": 1420070400 } <4>
GET my-index-000001/_search
{
"sort": { "date": "asc"} <5>
}
{ "index" : { "_id" : "3" } }
{ "date": 1420070400000 } <4>
GET my-index-000001/_search
{
"script_fields" : {
"my_field" : {
"script" : {
"lang" : "painless",
"source" : "doc['date'].value.nano" <6>
}
"sort": { "date": "asc"}, <5>
"runtime_mappings": {
"date_has_nanos": {
"type": "boolean",
"script": "emit(doc['date'].value.nano != 0)" <6>
}
}
}
GET my-index-000001/_search
{
"docvalue_fields" : [
},
"fields": [
{
"field" : "date",
"field": "date",
"format": "strict_date_optional_time_nanos" <7>
},
{
"field": "date_has_nanos"
}
]
}
--------------------------------------------------

----
// TEST[s/_search/_search?filter_path=hits.hits/]
<1> The `date` field uses the default `format`.
<2> This document uses a plain date.
<3> This document includes a time.
<4> This document uses milliseconds-since-the-epoch.
<5> Note that the `sort` values that are returned are all in
nanoseconds-since-the-epoch.
<6> Access the nanosecond part of the date in a script
<7> Use doc value fields, which can be formatted in nanosecond
resolution
<6> Use `.nano` in scripts to return the nanosecond component of the date.
<7> You can specify the format when fetching data using the <<search-fields-param,`fields` parameter>>.
Use <<strict-date-time-nanos,`strict_date_optional_time_nanos`>> or you'll get a rounded result.

////
[source,console-result]
----
{
"hits": {
"hits": [
{
"_id": "1",
"_index": "my-index-000001",
"_type": "_doc",
"_score": null,
"_source": {"date": "2015-01-01"},
"fields": {
"date": ["2015-01-01T00:00:00.000Z"],
"date_has_nanos": [false]
},
"sort": [1420070400000000000]
},
{
"_id": "3",
"_type": "_doc",
"_index": "my-index-000001",
"_score": null,
"_source": {"date": 1420070400000},
"fields": {
"date": ["2015-01-01T00:00:00.000Z"],
"date_has_nanos": [false]
},
"sort": [1420070400000000000]
},
{
"_id": "2",
"_index": "my-index-000001",
"_type": "_doc",
"_score": null,
"_source": {"date": "2015-01-01T12:10:30.123456789Z"},
"fields": {
"date": ["2015-01-01T12:10:30.123456789Z"],
"date_has_nanos": [true]
},
"sort": [1420114230123456789]
}
]
}
}
----
////

You can also specify multiple date formats separated by `||`. The
same mapping parameters than with the `date` field can be used.
Expand Down

0 comments on commit 247850f

Please sign in to comment.