java操作elasticsearch实现前缀查询、wildcard、fuzzy模糊查询、ids查询
生活随笔
收集整理的這篇文章主要介紹了
java操作elasticsearch实现前缀查询、wildcard、fuzzy模糊查询、ids查询
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
1、前綴查詢(prefix)
//prefix前綴查詢 @Testpublic void test15() throws UnknownHostException {//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名稱Settings settings = Settings.builder().put("cluster.name", "my-application").build();//2.創(chuàng)建訪問ES服務(wù)器的客戶端TransportClient client = new PreBuiltTransportClient(settings)//獲取es主機中節(jié)點的ip地址及端口號(以下是單個節(jié)點案例).addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));//prefixQuery 第一個參數(shù)為字段名,后面是以zhao開頭的條件進(jìn)行查詢QueryBuilder builder = QueryBuilders.prefixQuery("name", "zhao");SearchResponse response = client.prepareSearch("lib3").setQuery(builder).get();SearchHits hits = response.getHits();for(SearchHit hit:hits) {System.out.println(hit.getSourceAsString());//將獲取的值轉(zhuǎn)換成map的形式Map<String, Object> map = hit.getSourceAsMap();for(String key:map.keySet()) {System.out.println(key +" key對應(yīng)的值為:" +map.get(key));}}}2、wildcard模糊查詢
//wildcard模糊查詢 @Testpublic void test16() throws UnknownHostException {//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名稱Settings settings = Settings.builder().put("cluster.name", "my-application").build();//2.創(chuàng)建訪問ES服務(wù)器的客戶端TransportClient client = new PreBuiltTransportClient(settings)//獲取es主機中節(jié)點的ip地址及端口號(以下是單個節(jié)點案例).addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));//wildcardQuery模糊查詢QueryBuilder builder = QueryBuilders.wildcardQuery("name", "zhao*");SearchResponse response = client.prepareSearch("lib3").setQuery(builder).get();SearchHits hits = response.getHits();for(SearchHit hit:hits) {System.out.println(hit.getSourceAsString());//將獲取的值轉(zhuǎn)換成map的形式Map<String, Object> map = hit.getSourceAsMap();for(String key:map.keySet()) {System.out.println(key +" key對應(yīng)的值為:" +map.get(key));}} }3、fuzzy模糊查詢
說明:fuzzy才是實現(xiàn)真正的模糊查詢,我們輸入的字符可以是個大概,他可以根據(jù)我們輸入的文字大概進(jìn)行匹配查詢,具體可看文章中的解釋和代碼,注意與wildcard模糊查詢的區(qū)別
//fuzzy模糊查詢(輸入的值輸入個大概也可以查詢出來) @Testpublic void test17() throws UnknownHostException {//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名稱Settings settings = Settings.builder().put("cluster.name", "my-application").build();//2.創(chuàng)建訪問ES服務(wù)器的客戶端TransportClient client = new PreBuiltTransportClient(settings)//獲取es主機中節(jié)點的ip地址及端口號(以下是單個節(jié)點案例).addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));//fuzzyQuery模糊查詢QueryBuilder builder = QueryBuilders.fuzzyQuery("name", "chagge");SearchResponse response = client.prepareSearch("lib3").setQuery(builder).get();SearchHits hits = response.getHits();for(SearchHit hit:hits) {System.out.println(hit.getSourceAsString());//將獲取的值轉(zhuǎn)換成map的形式Map<String, Object> map = hit.getSourceAsMap();for(String key:map.keySet()) {System.out.println(key +" key對應(yīng)的值為:" +map.get(key));}}} //typeQuery類型查詢 @Testpublic void test18() throws UnknownHostException {//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名稱Settings settings = Settings.builder().put("cluster.name", "my-application").build();//2.創(chuàng)建訪問ES服務(wù)器的客戶端TransportClient client = new PreBuiltTransportClient(settings)//獲取es主機中節(jié)點的ip地址及端口號(以下是單個節(jié)點案例).addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));//typeQuery類型查詢QueryBuilder builder = QueryBuilders.typeQuery("blog");SearchResponse response = client.prepareSearch("index1").setQuery(builder).get();SearchHits hits = response.getHits();for(SearchHit hit:hits) {System.out.println(hit.getSourceAsString());//將獲取的值轉(zhuǎn)換成map的形式Map<String, Object> map = hit.getSourceAsMap();for(String key:map.keySet()) {System.out.println(key +" key對應(yīng)的值為:" +map.get(key));}}}4、ids查詢
說明:根據(jù)多個id值進(jìn)行查詢
//idsQuery id查詢(可以同時根據(jù)多個id進(jìn)行查詢) @Testpublic void test19() throws UnknownHostException {//1、指定es集群 cluster.name 是固定的key值,my-application是ES集群的名稱Settings settings = Settings.builder().put("cluster.name", "my-application").build();//2.創(chuàng)建訪問ES服務(wù)器的客戶端TransportClient client = new PreBuiltTransportClient(settings)//獲取es主機中節(jié)點的ip地址及端口號(以下是單個節(jié)點案例).addTransportAddress(new TransportAddress(InetAddress.getByName("192.168.1.94"), 9300));//idsQuery id查詢QueryBuilder builder = QueryBuilders.idsQuery("1","2");SearchResponse response = client.prepareSearch("lib3").setQuery(builder).get();SearchHits hits = response.getHits();for(SearchHit hit:hits) {System.out.println(hit.getSourceAsString());//將獲取的值轉(zhuǎn)換成map的形式Map<String, Object> map = hit.getSourceAsMap();for(String key:map.keySet()) {System.out.println(key +" key對應(yīng)的值為:" +map.get(key));}}}下一篇博客本人將書寫java操作elasticsearch實現(xiàn)聚合查詢。對后期博客感興趣的朋友可以關(guān)注交流,轉(zhuǎn)發(fā)請說明出處,本人的博客地址為:https://www.cnblogs.com/chenyuanbo/
技術(shù)在于交流!
?
轉(zhuǎn)載于:https://www.cnblogs.com/chenyuanbo/p/10296845.html
總結(jié)
以上是生活随笔為你收集整理的java操作elasticsearch实现前缀查询、wildcard、fuzzy模糊查询、ids查询的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C++11多线程----线程管理
- 下一篇: 武科大计算机专业分数线,武汉科技大学计算