Elasticsearch 是一個開源的分布式搜索引擎,常用于企業級搜索和分析。其可以快速地存儲、搜索和分析海量數據。Elasticsearch 官方提供了一個 Java API,可以方便地與 Elasticsearch 進行交互。除此之外,Elasticsearch 還提供了自己的查詢語言和一些稱為搜索 DSL(Domain Specific Language)的工具,以幫助用戶靈活地構建查詢語句和過濾器。
//連接Elasticsearch服務器
TransportClient client = new PreBuiltTransportClient(Settings.EMPTY)
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("localhost"), 9300));
//這是一個ES查詢語句的例子
SearchResponse response = client.prepareSearch("books")
.setTypes("novel")
.setQuery(QueryBuilders.matchQuery("title", "紅樓夢"))
.setSize(10)
.execute()
.actionGet();
//將查詢結果轉化為JSON格式
String json = response.toString();
上面的代碼中,我們使用 Java API 連接 Elasticsearch 服務器,并對名為“books”的索引中類型為“novel”的文檔執行了一個匹配查詢,篩選出了包含“紅樓夢”字段的文檔。查詢語句由 QueryBuilders 提供的 matchQuery 方法構建,該方法會將查詢關鍵字“紅樓夢”匹配文檔的 title 字段。setSize 方法限制了查詢結果的數量為 10 條。最后,我們將查詢結果轉化為 JSON 格式。
通過 Elasticsearch 的查詢語言和 Java API,我們可以非常便利地對 Elasticsearch 中的文檔進行搜索和過濾。而 Elasticsearch 返回的 JSON 結果也可以輕松地用于后續的處理和展示。作為一種強大的搜索引擎和數據分析工具,Elasticsearch 在企業級應用領域有著廣泛的應用。
上一篇vue回車觸發按鈕
下一篇mysql初始化元數據