7.SQL语法操作Elasticsearch之Elasticsearch-SQL插件安装(2019-05-17)

Elasticsearch 的查询语言(DSL)语法很复杂,查询的功能(filter/query/match/agg/geo)各种各样,不管是通过 restful API 还是通过 java 的 API 进行操作,都非常不方便。而 Elasticsearch-SQL 插件可以使用传统 SQL 语法查询 Elasticsearch,使用起来非常不错。

Elasticsearch-SQL 项目地址:https://github.com/NLPchina/elasticsearch-sql

1.简介:
Elasticsearch-SQL 实现的功能:
1).插件式的安装。
2).SQL语法查询。
3).超越SQL之外的查询。
4).对JDBC方式的支持。


2.插件安装:
我们使用的es版本是7.0.1,如果你用的是不同版本,可以在 https://github.com/NLPchina/elasticsearch-sql 找到支持(。
[root@bogon es]#  cd /home/es/elasticsearch-7.0.1
[root@bogon es]#  ./bin/elasticsearch-plugin install https://github.com/NLPchina/elasticsearch-sql/releases/download/7.0.1.0/elasticsearch-sql-7.0.1.0.zip
如果成功,命令行打印如下信息:

需要重启 elasticsearch 服务器,不然使用的时候会报如下错误:
{"error":{"root_cause":[{"type":"illegal_argument_exception","reason":"No endpoint or operation is available at [sql]"}],"type":"illegal_argument_exception","reason":"No endpoint or operation is available at [sql]"},"status":400}


3.重启下elasticsearch服务:
[root@bogon root]# ps -ef | grep elasticsearch  #找到进程号
[root@bogon root]# kill -9 进程号
[root@bogon root]# su elastic
[elastic@bogon root]$ ES_PATH_CONF=/home/es/elasticsearch/config sh /home/es/elasticsearch-7.0.1/bin/elasticsearch -d 


4.SQL查询:
安装成功以后我们就可以通过SQL查询ES了。
1).先灌入一些数据:

POST /tvs/sales/_bulk
{ "index": {}}
{ "price" : 1000, "color" : "红色", "brand" : "长虹", "sold_date" : "2016-10-28" }
{ "index": {}}
{ "price" : 2000, "color" : "红色", "brand" : "长虹", "sold_date" : "2016-11-05" }
{ "index": {}}
{ "price" : 3000, "color" : "绿色", "brand" : "小米", "sold_date" : "2016-05-18" }
{ "index": {}}
{ "price" : 1500, "color" : "蓝色", "brand" : "TCL", "sold_date" : "2016-07-02" }
{ "index": {}}
{ "price" : 1200, "color" : "绿色", "brand" : "TCL", "sold_date" : "2016-08-19" }
{ "index": {}}
{ "price" : 2000, "color" : "红色", "brand" : "长虹", "sold_date" : "2016-11-05" }
{ "index": {}}
{ "price" : 8000, "color" : "红色", "brand" : "三星", "sold_date" : "2017-01-01" }
{ "index": {}}
{ "price" : 2500, "color" : "蓝色", "brand" : "小米", "sold_date" : "2017-02-12" }

2).使用方式,这里简单介绍两种:
①.在 kibana 界面的Dev Tools里面输入:GET  _sql?sql=select * from tvs where price > 1000
②.在浏览器地址栏输入:http://192.168.75.206:9200/_sql?sql=select * from tvs where price > 1000

 

 

5.安装Elasticsearch-SQL Site chrome扩展,使用更方便的查询方式:
1).下载扩展ZIP包:https://github.com/shi-yuan/elasticsearch-sql-site-chrome
2).解压。
3).在chrome浏览器输入:chrome://extensions/
4).开启开发者模式。
5).加载已解压的扩展程序。6).使用时点击扩展图标即可,可以将 SQL 语句翻译成 DSL 。

 

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值