Elasticsearch SQL

2018-08-01 14:39:36 浏览数 (1)

1. 简介

Elasticsearch 6.3.0 正式发布了,其中有一个重要特性:原生支持 SQL 了,不需要任何外部其他的库、处理方式等等,开箱即用。

REST 接口、命令行、JDBC 各种方式都支持使用 SQL 进行查询和聚合操作,Elasticsearch SQL 就像一个翻译器,它即懂得 SQL 也懂 Elasticsearch,帮助我们方便的使用 SQL 来实时处理 ES 的数据,可读性非常好,又可以很好的发挥 ES 的能力。

2. 示例

(1)插入测试数据

代码语言:javascript复制
curl -X PUT "localhost:9200/library/book/_bulk?refresh" 
     -H 'Content-Type: application/json' -d'

{"index":{"_id": "Leviathan Wakes"}}
{"name": "Leviathan Wakes", "author": "James S.A. Corey", "release_date": "2011-06-02", "page_count": 561}
{"index":{"_id": "Hyperion"}}
{"name": "Hyperion", "author": "Dan Simmons", "release_date": "1989-05-26", "page_count": 482}
{"index":{"_id": "Dune"}}
{"name": "Dune", "author": "Frank Herbert", "release_date": "1965-06-01", "page_count": 604}
'

(2)使用 SQL 查询所有数据

(3)order by 和 limit

(4)SQL 和 ES filter 联合使用

(5)把 SQL 转成 ES 查询方式

结果

(6)使用 SQL 客户端

登录 sql-cli

bin/elasticsearch-sql-cli

执行 sql

3. 小结

SQL 是开发人员非常熟悉的语言,新版 ES 原生支持 SQL 后会给我们带来了极大的便利,有兴趣的同学可以体验一下。

安装文档

https://www.elastic.co/guide/en/elasticsearch/reference/current/install-elasticsearch.html

Elasticsearch SQL 文档

https://www.elastic.co/guide/en/elasticsearch/reference/current/xpack-sql.html

0 人点赞