用于 IntelliJ IDEA 的新 ES|QL 插件

作者:来自 Elastic Laura Trotta

使用 IntelliJ IDEA 的新插件,在你的 IDE 中构建并运行 ES|QL 查询。

通过 Elasticsearch 实践操作:深入了解 Elasticsearch Labs 仓库中的示例 notebooks,开始免费云试用,或现在就在你的本地机器上尝试 Elastic。


Elasticsearch 查询语言( ES|QL )Elasticsearch 的管道式查询语言,旨在实现直观的数据查询和操作。请参考我们的入门指南以了解更多信息。

Elasticsearch Java 客户端通过 DSL 支持 ES|QL 查询,但目前它将查询视为简单 字符串 ,没有专门的辅助工具;虽然 Kibana 提供了出色的 UI 来构建 ES|QL查询,但我们也意识到,有时在集成开发环境( IDE )中拥有编写应用程序所需的一切会带来更好的体验。因此,在 Java 客户端将其类型支持扩展到 ES|QL 之前,我们编写了一个 IntelliJ IDEA 插件,用于自动补全、语法检查、显示文档以及执行 ES|QL 查询。

该插件目前支持 Java、 Kotlin 和纯文本文件,以防 Java 虚拟机( JVM )不是你的选择。

请在 JetBrains Marketplace 页面GitHub 仓库中查看它,以获取更多信息。

前提条件

  • IDE:Intellij IDEA 版本 >= 253( community 或 ultimate )

使用方法

像安装其他插件一样在 Intellij IDEA 中安装该插件,可以通过 JetBrains marketplace,或者进入 Settings -> Plugins -> Marketplace 并搜索 " esql "。

以下示例使用 Java 编写,但也支持 Kotlin,使用方式基本相同。

创建一个文本块字符串,在其上方写一个简单注释 " ES|QL ",即可完成。

ini 复制代码
`

1.  // ES|QL
2.  String query = """
3.  """;

`AI写代码

然后一切即可正常工作,你已经准备好编写你的查询。

为什么使用文本块而不是简单字符串?ES|QL 语法在多种上下文中接受引号,对其进行转义会在语法检查器中触发其他错误,因此我们选择使用文本块来保持简单。

对于 txt 文件来说更简单,因为你只需添加该注释,然后直接在下方开始编写查询:

arduino 复制代码
`// ES|QL`AI写代码

连接到服务器 实例

该插件可以连接到 Elasticsearch 服务器实例,以获取索引和字段名称,然后将它们添加到自动补全选项中。请在屏幕左下角(或你放置工具的位置)查找 Elastic 标志,并配置你到任意服务器实例的连接:

自动补全

在文本块中开始输入时,会自动打开自动补全弹窗,它会返回一个可接受的命令/值列表,帮助你正确继续编写查询。如果你想手动触发自动补全,可以使用 IDE 的快捷键 ctrl + space:

语法检查

该插件会高亮查询中的错误,并说明需要修复的内容:

文档

将光标悬停在命令上会显示文档,说明该命令的用途以及其正确语法:

运行查询

连接到服务器实例后,你可以点击 Elastic 图标旁边的绿色按钮来运行查询:结果将显示在工具窗口中:

或者如果你正在编写应用程序,可以像这样使用 Java 客户端:

ini 复制代码
`

1.  // ES|QL
2.  String query = """
3.  	FROM my-index
4.  | SORT year DESC
5.  | LIMIT 10
6.  """;

8.  try (ElasticsearchClient client = ElasticsearchClient.of(e -> e
9.                  .host(serverUrl)
10.                  .apiKey(apiKey))) {

12.  client.esql().query(QueryRequest.of(qr -> qr.query(query)));

14.  }

`AI写代码![](https://csdnimg.cn/release/blogv2/dist/pc/img/runCode/icon-arrowwhite.png)

查看我们之前关于 ES|QL Java Client 的文章,以获取将 ES|QL 结果映射到 Java 对象的完整示例。

它是如何工作的?

这里没有 AI 参与;该插件基于 ES|QL ANTLR 语法来实现自动补全和语法检查,并使用 Elasticsearch 文档来展示说明。

结论

该插件仍处于实验阶段,因此欢迎你在 GitHub 仓库中提交任何 bug 或功能请求。

原文:www.elastic.co/search-labs...

相关推荐
历程里程碑1 小时前
MySQL数据类型全解析 + 代码实操讲解
大数据·开发语言·数据库·sql·mysql·elasticsearch·搜索引擎
绘梨衣5471 小时前
django-elasticsearch-dsl-drf 搜索服务搭建教学文档
python·elasticsearch·django
Adolf_19932 小时前
Mac 配置Homebrew + Oh My Zsh + npm全局权限问题
大数据·elasticsearch·搜索引擎
二哈赛车手18 小时前
新人笔记---ES和kibana启动问题以及一些常用的linux的错误排查方法,以及ES,数据库泄密解决方案[超详细]
java·linux·数据库·spring boot·笔记·elasticsearch
摇滚侠1 天前
数据同步 黑马 Elasticsearch 全套教程,黑马旅游网案例
大数据·elasticsearch·搜索引擎
南棱笑笑生1 天前
20260503给万象奥科的开发板HD-RK3576-PI适配瑞芯微原厂的Android14时适配AP6256
大数据·elasticsearch·搜索引擎·rockchip
逸Y 仙X1 天前
文章二十:Elasticsearch高亮搜索完全指南
java·大数据·运维·elasticsearch·搜索引擎·全文检索
Elastic 中国社区官方博客2 天前
ES|QL METRICS_INFO 和 TS_INFO:为你的时间序列数据建立目录
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索
Elastic 中国社区官方博客2 天前
Elastic 和 Cursor 合作 加速 上下文工程 与 coding agents
大数据·人工智能·elasticsearch·搜索引擎·全文检索
二哈赛车手2 天前
新人笔记---实现简易版的rag的bm25检索(利用ES),以及RAG上传时的ES与向量数据库双写
java·数据库·笔记·spring·elasticsearch·ai