Loading

Elastic Stack:es7 sql新特性

一.入门

查询所有

1
2
3
4
POST /_sql?format=txt
{
    "query": "SELECT * FROM tvs "
}

 按颜色分组,查询价格的最大值、最小值、总和、平均值

1
2
3
4
POST /_sql?format=txt
{
  "query": "select color,sum(price),min(price),max(price),avg(price) from tvs group by color"
}

sql翻译:

1
2
3
4
POST /_sql/translate
{
    "query": "SELECT * FROM tvs "
}

 返回:

与DSL混用:

1
2
3
4
5
6
7
8
9
10
11
12
POST /_sql?format=txt
{
    "query": "SELECT * FROM tvs",
    "filter": {
        "range": {
            "price": {
                "gte" : 1200,
                "lte" : 2000
            }
        }
    }

 二.elasticsearch-sql-cli

进入elasticsearch的安装目录

1
2
cd bin
./elasticsearch-sql-cli

 然后再sql命令行可以执行sql语句

三.java代码实现sql功能

在kibana中开启白金版试用

 

加入相关功能的依赖:

1
2
3
4
5
6
7
8
9
10
11
12
<dependency>
    <groupId>org.elasticsearch.plugin</groupId>
    <artifactId>x-pack-sql-jdbc</artifactId>
    <version>7.3.0</version>
</dependency>
 
<repositories><!-- 如果jar包下载不下来,就需要在pom文件中配置一下仓库 -->
    <repository>
        <id>elastic.co</id>
        <url>https://artifacts.elastic.co/maven</url>
    </repository>
</repositories>  

  测试:

1
2
3
4
5
6
7
8
9
10
11
12
13
//创建连接
Connection connection = DriverManager.getConnection("jdbc:es://http://192.168.10.138:9200");
//创建statement
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery("select * from tvs");
//获取结果
while (resultSet.next()){
    System.out.println(resultSet.getString(1));
    System.out.println(resultSet.getString(2));
    System.out.println(resultSet.getString(3));
    System.out.println(resultSet.getString(4));
    System.out.println("--------");
}

posted @   秋风飒飒吹  阅读(1022)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示