2017-12-13 10:19:31 -05:00
|
|
|
[role="xpack"]
|
|
|
|
[[sql-jdbc]]
|
|
|
|
== SQL JDBC
|
|
|
|
|
2018-02-02 09:58:39 -05:00
|
|
|
Elasticsearch's SQL jdbc driver is a rich, fully featured JDBC driver for Elasticsearch.
|
2018-02-02 11:06:35 -05:00
|
|
|
It is Type 4 driver, meaning it is a platform independent, stand-alone, Direct to Database,
|
2018-02-02 09:58:39 -05:00
|
|
|
pure Java driver that converts JDBC calls to Elasticsearch SQL.
|
2017-12-20 13:58:32 -05:00
|
|
|
|
2018-02-02 11:06:35 -05:00
|
|
|
// TODO add example of resolving the artifact in maven and gradle.
|
2017-12-20 13:58:32 -05:00
|
|
|
|
|
|
|
You can connect to it using the two APIs offered
|
2017-12-13 10:19:31 -05:00
|
|
|
by JDBC, namely `java.sql.Driver` and `DriverManager`:
|
|
|
|
|
|
|
|
["source","java",subs="attributes,callouts,macros"]
|
|
|
|
--------------------------------------------------
|
|
|
|
include-tagged::{jdbc-tests}/JdbcIntegrationTestCase.java[connect-dm]
|
|
|
|
--------------------------------------------------
|
|
|
|
<1> The server and port on which Elasticsearch is listening for
|
2018-02-02 09:58:39 -05:00
|
|
|
HTTP traffic. The port is by default 9200.
|
2017-12-13 10:19:31 -05:00
|
|
|
<2> Properties for connecting to Elasticsearch. An empty `Properties`
|
|
|
|
instance is fine for unsecured Elasticsearch.
|
|
|
|
|
2017-12-20 13:58:32 -05:00
|
|
|
or `javax.sql.DataSource` through
|
2017-12-13 10:19:31 -05:00
|
|
|
["source","java",subs="attributes,callouts,macros"]
|
|
|
|
--------------------------------------------------
|
|
|
|
include-tagged::{jdbc-tests}/JdbcIntegrationTestCase.java[connect-ds]
|
|
|
|
--------------------------------------------------
|
|
|
|
<1> The server and port on which Elasticsearch is listening for
|
2018-02-02 09:58:39 -05:00
|
|
|
HTTP traffic. By default 9200.
|
2017-12-13 10:19:31 -05:00
|
|
|
<2> Properties for connecting to Elasticsearch. An empty `Properties`
|
|
|
|
instance is fine for unsecured Elasticsearch.
|
|
|
|
|
|
|
|
Which one to use? Typically client applications that provide most
|
|
|
|
configuration parameters in the URL rely on the `DriverManager`-style
|
|
|
|
while `DataSource` is preferred when being _passed_ around since it can be
|
|
|
|
configured in one place and the consumer only has to call `getConnection`
|
|
|
|
without having to worry about any other parameters.
|
|
|
|
|
|
|
|
To connect to a secured Elasticsearch server the `Properties`
|
|
|
|
should look like:
|
|
|
|
|
|
|
|
["source","java",subs="attributes,callouts,macros"]
|
|
|
|
--------------------------------------------------
|
|
|
|
include-tagged::{security-tests}/JdbcSecurityIT.java[admin_properties]
|
|
|
|
--------------------------------------------------
|
|
|
|
|
|
|
|
Once you have the connection you can use it like any other JDBC
|
|
|
|
connection. For example:
|
|
|
|
|
|
|
|
["source","java",subs="attributes,callouts,macros"]
|
|
|
|
--------------------------------------------------
|
|
|
|
include-tagged::{jdbc-tests}/SimpleExampleTestCase.java[simple_example]
|
|
|
|
--------------------------------------------------
|
2018-02-01 17:20:44 -05:00
|
|
|
|
|
|
|
[[sql-jdbc-permissions]]
|
|
|
|
[NOTE]
|
|
|
|
===============================
|
|
|
|
If you are using Security you need to add a few permissions to
|
|
|
|
users so they can run SQL. To run SQL a user needs `read` and
|
|
|
|
`indices:admin/get`. Some parts of the API require
|
|
|
|
`"cluster:monitor/main"`. The following example configures a
|
|
|
|
role that can run SQL in JDBC querying the `test` and `bort`
|
|
|
|
indices:
|
|
|
|
|
|
|
|
["source","yaml",subs="attributes,callouts,macros"]
|
|
|
|
--------------------------------------------------
|
|
|
|
include-tagged::{sql-tests}/security/roles.yml[cli_jdbc]
|
|
|
|
--------------------------------------------------
|
|
|
|
===============================
|