2017-12-13 10:19:31 -05:00
|
|
|
[role="xpack"]
|
|
|
|
[[sql-translate]]
|
|
|
|
== SQL Translate API
|
|
|
|
|
|
|
|
The SQL Translate API accepts SQL in a JSON document and translates it
|
|
|
|
into native Elasticsearch queries. For example:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
POST /_xpack/sql/translate
|
|
|
|
{
|
|
|
|
"query": "SELECT * FROM library ORDER BY page_count DESC",
|
|
|
|
"fetch_size": 10
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
|
|
|
// CONSOLE
|
|
|
|
// TEST[setup:library]
|
|
|
|
|
|
|
|
Which returns:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
{
|
|
|
|
"size" : 10,
|
|
|
|
"docvalue_fields" : [
|
2018-05-23 08:39:04 -04:00
|
|
|
{
|
|
|
|
"field": "page_count",
|
|
|
|
"format": "use_field_mapping"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"field": "release_date",
|
|
|
|
"format": "epoch_millis"
|
|
|
|
}
|
2017-12-13 10:19:31 -05:00
|
|
|
],
|
2017-12-18 20:57:50 -05:00
|
|
|
"_source": {
|
|
|
|
"includes": [
|
|
|
|
"author",
|
|
|
|
"name"
|
|
|
|
],
|
|
|
|
"excludes": []
|
|
|
|
},
|
2017-12-13 10:19:31 -05:00
|
|
|
"sort" : [
|
|
|
|
{
|
|
|
|
"page_count" : {
|
|
|
|
"order" : "desc"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
|
|
|
// TESTRESPONSE
|
|
|
|
|
|
|
|
Which is the request that SQL will run to provide the results.
|
|
|
|
In this case, SQL will use the <<search-request-scroll,scroll>>
|
|
|
|
API. If the result contained an aggregation then SQL would use
|
|
|
|
the normal <<search-request-body,search>> API.
|
|
|
|
|
|
|
|
The request body accepts all of the <<sql-rest-fields,fields>> that
|
|
|
|
the <<sql-rest,SQL REST API>> accepts except `cursor`.
|
2018-02-01 17:20:44 -05:00
|
|
|
|
|
|
|
[[sql-translate-permissions]]
|
|
|
|
[NOTE]
|
|
|
|
===============================
|
|
|
|
If you are using Security you need to add a few permissions to
|
|
|
|
users so they can run translate SQL. To translate SQL a user
|
|
|
|
needs `read` and `indices:admin/get`. The following example
|
|
|
|
configures a role that can run SQL against the `test` and
|
|
|
|
`bort` indices:
|
|
|
|
|
|
|
|
["source","yaml",subs="attributes,callouts,macros"]
|
|
|
|
--------------------------------------------------
|
|
|
|
include-tagged::{sql-tests}/security/roles.yml[rest]
|
|
|
|
--------------------------------------------------
|
|
|
|
===============================
|