文章出處
文章列表
前言:
solr服務器搭起來, 數據導入之后, 就該應用到項目中去了. 那在項目中, 該怎么整合和應用solr呢?
接下來, 就來整合和應用solr
一. 整合
1. 引入jar包
<properties> <spring.data.solr.version>2.1.1.RELEASE</spring.data.solr.version> </properties> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-solr</artifactId> <version>${spring.data.solr.version}</version> </dependency> </dependencies> </dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-solr</artifactId> </dependency> <!-- 默認 starter 會加載 solrj 進來, 下面這個可不引--> <dependency> <groupId>org.apache.solr</groupId> <artifactId>solr-solrj</artifactId> <version>6.6.2</version> </dependency> </dependencies>
2. 配置文件
spring:
data:
solr:
host: http://127.0.0.1:8081/solr
host 也可以寫成 http://127.0.0.1:8081/solr/collection1.
這里的collection1是 core 的名字, 可以在 core admin 選項中進行配置.
collection1 這里可以理解為數據庫的概念. 在操作的時, 如果有多個core, 可以切換數據庫. 也就是切換 core
二. 索引和查詢
package org.elvin.mysolr.controller; import org.apache.solr.client.solrj.SolrClient; import org.apache.solr.client.solrj.SolrQuery; import org.apache.solr.client.solrj.response.QueryResponse; import org.apache.solr.common.SolrDocument; import org.apache.solr.common.SolrDocumentList; import org.apache.solr.common.SolrInputDocument; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.List; import java.util.Map; import java.util.UUID; @RestController @RequestMapping("solr") public class SolrController { @Autowired private SolrClient client; /** * 新增/修改 索引
* 當 id 存在的時候, 此方法是修改(當然, 我這里用的 uuid, 不會存在的), 如果 id 不存在, 則是新增 * @return */ @RequestMapping("add") public String add() { String uuid = UUID.randomUUID().toString().replaceAll("-", ""); try { SolrInputDocument doc = new SolrInputDocument(); doc.setField("id", uuid); doc.setField("content_ik", "我是中國人, 我愛中國"); /* 如果spring.data.solr.host 里面配置到 core了, 那么這里就不需要傳 collection1 這個參數 * 下面都是一樣的 */ client.add("collection1", doc); //client.commit(); client.commit("collection1"); return uuid; } catch (Exception e) { e.printStackTrace(); } return "error"; } /** * 根據id刪除索引 * @param id * @return */ @RequestMapping("delete") public String delete(String id) { try { client.deleteById("collection1",id); client.commit("collection1"); return id; } catch (Exception e) { e.printStackTrace(); } return "error"; } /** * 刪除所有的索引 * @return */ @RequestMapping("deleteAll") public String deleteAll(){ try { client.deleteByQuery("collection1","*:*"); client.commit("collection1"); return "success"; } catch (Exception e) { e.printStackTrace(); } return "error"; } /** * 根據id查詢索引 * @return * @throws Exception */ @RequestMapping("getById") public String getById() throws Exception { SolrDocument document = client.getById("collection1", "536563"); System.out.println(document); return document.toString(); } /** * 綜合查詢: 在綜合查詢中, 有按條件查詢, 條件過濾, 排序, 分頁, 高亮顯示, 獲取部分域信息 * @return */ @RequestMapping("search") public Map<String, Map<String, List<String>>> search(){ try { SolrQuery params = new SolrQuery(); //查詢條件, 這里的 q 對應 下面圖片標紅的地方 params.set("q", "手機"); //過濾條件 params.set("fq", "product_price:[100 TO 100000]"); //排序 params.addSort("product_price", SolrQuery.ORDER.asc); //分頁 params.setStart(0); params.setRows(20); //默認域 params.set("df", "product_title"); //只查詢指定域 params.set("fl", "id,product_title,product_price"); //高亮 //打開開關 params.setHighlight(true); //指定高亮域 params.addHighlightField("product_title"); //設置前綴 params.setHighlightSimplePre("<span style='color:red'>"); //設置后綴 params.setHighlightSimplePost("</span>"); QueryResponse queryResponse = client.query(params); SolrDocumentList results = queryResponse.getResults(); long numFound = results.getNumFound(); System.out.println(numFound);
//獲取高亮顯示的結果, 高亮顯示的結果和查詢結果是分開放的 Map<String, Map<String, List<String>>> highlight = queryResponse.getHighlighting(); for (SolrDocument result : results) { System.out.println(result.get("id")); System.out.println(result.get("product_title")); //System.out.println(result.get("product_num")); System.out.println(result.get("product_price")); //System.out.println(result.get("product_image")); Map<String, List<String>> map = highlight.get(result.get("id")); List<String> list = map.get("product_title"); System.out.println(list.get(0)); System.out.println("------------------"); System.out.println(); } return highlight; } catch (Exception e) { e.printStackTrace(); } return null; } }
三. 補充
這里特別需要補充一點的是, 在頁面上執行增改查, 都很方便, 感覺是在做填空題.
但是刪除的時候, 貌似不能直接填空了. 有點特別
這里需要使用 xml 的方式操作, 且必須加上 commit, 下面的1000ms自動提交, 不適用于delete
<!--刪除所有索引-->
<delete> <query>*:*</query> </delete> <commit />
<!-- 根據 id 進行刪除-->
<delete>
<id>1</id>
</delete>
<commit />
文章列表
全站熱搜