1: Solr导入

1.1导入POM

# Base Code Java org.apache.solr solr-solrj 8.4.0 # spring boot org.springframework.boot spring-boot-starter-data-solr

# Base Code Java
<dependency>
<groupId>org.apache.solr</groupId>
<artifactId>solr-solrj</artifactId>
<version>8.4.0</version>
</dependency>
# spring boot
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-solr</artifactId>
</dependency>

2 SolrJ概述

对Solr的所有请求均由发送SolrClient

SolrClient 有一些具体的实现,每个实现都针对不同的使用模式或弹性模型:

  • HttpSolrClient-面向以查询为中心的工作负载,尽管它也是一个很好的通用客户端。直接与单个Solr节点通信。
  • Http2SolrClient-利用HTTP / 2的异步,非阻塞和通用客户端。此类是实验性的,因此它的API可能会在次要版本的SolrJ中更改或删除。
  • LBHttpSolrClient-在Solr节点列表之间平衡请求负载。根据节点运行状况调整“服务中”节点的列表。
  • LBHttp2SolrClient-就像LBHttpSolrClientHttp2SolrClient改用。此类是实验性的,因此它的API可能会在次要版本的SolrJ中更改或删除。
  • CloudSolrClient-旨在与SolrCloud部署进行通信。使用已经记录的ZooKeeper状态来发现请求并将其路由到健康的Solr节点。
  • ConcurrentUpdateSolrClient-面向以索引为中心的工作负载。在将较大的批次发送到Solr之前,在内部缓冲文档。
  • ConcurrentUpdateSolrClient-就像ConcurrentUpdateSolrClientHttp2SolrClient改用。此类是实验性的,因此它的API可能会在次要版本的SolrJ中更改或删除

3: 声明网址

大多数SolrClient实现(CloudSolrClient和除外Http2SolrClient)都要求用户指定一个或多个Solr基本URL,然后客户端将其用于将HTTP请求发送到Solr。从那时起,用户在其提供的基本URL上包括的路径会影响所创建客户端的行为。

  1. 具有指向特定核心或集合(例如http://hostname:8983/solr/core1)的路径的URL 。如果在基本URL中指定了核心或集合,则不需要对该客户端进行的后续请求来重新指定受影响的集合。但是,客户端仅限于将请求发送到该核心/集合,而不能将请求发送到任何其他请求。
  2. 指向根Solr路径的URL(例如http://hostname:8983/solr)。如果在基本URL中未指定任何核心或集合,则可以对任何核心/集合进行请求,但是必须在所有请求上指定受影响的核心/集合。

4: 自定义SolrClient

SolrClient实现都允许用户指定连接并读取与Solr通信的超时

final String solrUrl = "http://localhost:8983/solr";
return new HttpSolrClient.Builder(solrUrl)
.withConnectionTimeout(10000)
.withSocketTimeout(60000)
.build();

Solr Cloud 集群实现是 SolrJ的CloudSolrClient实现(CloudSolrClientCloudHttp2SolrClien

5: SolrJ创建文档

//http://localhost:8080/saveOrUpdate?id=1&name=dgw&age=24
@GetMapping("saveOrUpdate")
public String saveOrUpdate(Admin admin) {
if (admin.getId() == null) {
admin.setId(System.currentTimeMillis());
}
try { #使用 SolrInputDocument
final SolrInputDocument doc = new SolrInputDocument();
doc.setField("id", admin.getId());
doc.setField("name", admin.getName());
doc.setField("age", admin.getAge());
// collectionName 文档名称
solrClient.add(solrConfig.collectionName, doc);
solrClient.commit(solrConfig.collectionName);
return admin.toString();
} catch (SolrServerException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return "error";
}

6Solr复杂查询

final SolrClient client = getSolrClient();

final Map<String, String> queryParamMap = new HashMap<String, String>();
queryParamMap.put("q", "*:*");
queryParamMap.put("fl", "id, name");
queryParamMap.put("sort", "id asc");
MapSolrParams queryParams = new MapSolrParams(queryParamMap); final QueryResponse response = client.query("techproducts", queryParams);
final SolrDocumentList documents = response.getResults(); print("Found " + documents.getNumFound() + " documents");
for(SolrDocument document : documents) {
final String id = (String) document.getFirstValue("id");
final String name = (String) document.getFirstValue("name"); print("id: " + id + "; name: " + name);
}

7: CRUD查询例子

package com.dgw.springbootsolr.controller;

import com.dgw.springbootsolr.config.SolrConfig;
import com.dgw.springbootsolr.entity.Admin;
import com.dgw.springbootsolr.entity.Goods;
import org.apache.solr.client.solrj.SolrClient;
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrServerException;
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.apache.solr.common.util.NamedList;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController; import java.io.IOException;
import java.util.HashMap;
import java.util.List;
import java.util.Map; /**
* @program: springboot-solr
* @description:
* @author: Mr.Dai
* @create: 2020-02-26 21:09
**/
@RestController
public class SolrController { @Autowired
public SolrClient solrClient; @Autowired
private SolrConfig solrConfig; //http://localhost:8080/saveOrUpdate?id=1&name=dgw&age=24
@GetMapping("saveOrUpdate")
public String saveOrUpdate(Admin admin) {
if (admin.getId() == null) {
admin.setId(System.currentTimeMillis());
}
try {
final SolrInputDocument doc = new SolrInputDocument();
doc.setField("id", admin.getId());
doc.setField("name", admin.getName());
doc.setField("age", admin.getAge());
// collectionName 文档名称
solrClient.add(solrConfig.collectionName, doc);
solrClient.commit(solrConfig.collectionName);
return admin.toString();
} catch (SolrServerException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return "error";
} /**
* 根据id删除索引
* //http://localhost:8080/delete?id=1
*/
@GetMapping("delete")
public String delete(String id) {
try {
solrClient.deleteById(solrConfig.collectionName, id);
solrClient.commit(solrConfig.collectionName);
return id;
} catch (Exception e) {
e.printStackTrace();
}
return "error";
} /**
* 删除所有的索引
* http://localhost:8080/deleteAll
*/
@GetMapping("deleteAll")
public String deleteAll() {
try {
solrClient.deleteByQuery(solrConfig.collectionName, "*:*");
solrClient.commit(solrConfig.collectionName);
return "success";
} catch (Exception e) {
e.printStackTrace();
}
return "error";
} /**
* 根据id查询索引
* http://localhost:8080/getGoodsById?id=1
*/
@GetMapping("getGoodsById")
public String getGoodsById(String id) throws Exception {
SolrDocument document = solrClient.getById(solrConfig.collectionName, id);
return document.toString();
} //http://localhost:8080/addBean
@GetMapping("addBean")
public String addBean() {
Admin dgw2 = new Admin(1L, "dgw2", 25);
try {
solrClient.addBean(solrConfig.collectionName, dgw2);
solrClient.commit(solrConfig.collectionName);
} catch (IOException | SolrServerException e) {
e.printStackTrace();
}
return "error";
} // http://localhost:8080/search
@GetMapping("search")
public Map<String, Object> search() {
final SolrQuery solrQuery = new SolrQuery("*:*");
solrQuery.addField("id");
solrQuery.addField("name");
solrQuery.addField("age");
solrQuery.setSort("id", SolrQuery.ORDER.asc); //设置高亮前缀
solrQuery.setHighlightSimplePre("<span style='color:red'>");
//设置高亮后缀
solrQuery.setHighlightSimplePost("</span>"); //指定高亮域
solrQuery.addHighlightField("id");
solrQuery.addHighlightField("name");
solrQuery.setHighlightFragsize(1);
//打开开关
solrQuery.setHighlight(true); //返回集合
Map<String, Object> returnMap = new HashMap(16);
try {
QueryResponse query = solrClient.query(solrConfig.collectionName, solrQuery); SolrDocumentList results = query.getResults();
//返回行数
long numFound = results.getNumFound();
//获取高亮显示的结果, 高亮显示的结果和查询结果是分开放的
Map<String, Map<String, List<String>>> highlight = query.getHighlighting();
System.out.println(results);
System.out.println(highlight);
results.forEach(result -> {
Map map = highlight.get(result.get("id"));
result.addField("nameHH", map.get("name"));
});
returnMap.put("results", results);
return returnMap;
} catch (SolrServerException | IOException e) {
e.printStackTrace();
}
return new HashMap<String, Object>() {
{
put("id", "1");
put("name", "ggg");
put("age", "12");
}
};
} /**
* 综合查询: 在综合查询中, 有按条件查询, 条件过滤, 排序, 分页, 高亮显示, 获取部分域信息
*
* @return
*/
@GetMapping("search2")
public Map<String, Object> search2(String keyword) {
//返回集合
Map<String, Object> returnMap = new HashMap();
try {
SolrQuery params = new SolrQuery();
//查询条件
params.set("q", keyword);
//过滤条件
params.set("fq", "goodsPrice:[100 TO 100000]");
//排序
params.addSort("id", SolrQuery.ORDER.asc);
//分页
//从第几条记录开始
params.setStart(0);
//最多返回多少条记录
params.setRows(20);
//默认域
params.set("df", "goodsIntroduce");
//只查询指定域
params.set("fl", "id,goodsName,goodsIntroduce,goodsPrice");
//高亮
//打开开关
params.setHighlight(true);
//指定高亮域
params.addHighlightField("goodsIntroduce");
params.addHighlightField("goodsName");
//设置高亮前缀
params.setHighlightSimplePre("<span style='color:red'>");
//设置高亮后缀
params.setHighlightSimplePost("</span>");
QueryResponse queryResponse = solrClient.query(solrConfig.collectionName, params);
SolrDocumentList results = queryResponse.getResults();
//返回行数
long numFound = results.getNumFound();
//获取高亮显示的结果, 高亮显示的结果和查询结果是分开放的
Map<String, Map<String, List<String>>> highlight = queryResponse.getHighlighting();
results.forEach(result -> {
Map map = highlight.get(result.get("id"));
result.addField("goodsNameHH", map.get("goodsName"));
result.addField("goodsIntroduceHH", map.get("goodsIntroduce"));
});
returnMap.put("numFound", numFound);
returnMap.put("results", results);
return returnMap;
} catch (Exception e) {
e.printStackTrace();
}
return null;
} //http://localhost:8080/test
@GetMapping("/test")
public String test() {
//System.out.println(solrConfig.collectionName);
return solrConfig.collectionName;
}
}

Solr系列4-SolrJ开发应用的更多相关文章

  1. [摘]全文检索引擎Solr系列—–全文检索基本原理

    原文链接--http://www.importnew.com/12707.html 全文检索引擎Solr系列—–全文检索基本原理 2014/08/18 | 分类: 基础技术, 教程 | 2 条评论 | ...

  2. Solr系列四:Solr(solrj 、索引API 、 结构化数据导入)

    一.SolrJ介绍 1. SolrJ是什么? Solr提供的用于JAVA应用中访问solr服务API的客户端jar.在我们的应用中引入solrj: <dependency> <gro ...

  3. Solr JAVA客户端SolrJ 4.9使用示例教程

    http://my.oschina.net/cloudcoder/blog/305024 简介 SolrJ是操作Solr的JAVA客户端,它提供了增加.修改.删除.查询Solr索引的JAVA接口.So ...

  4. Solr使用初探——SolrJ的使用

    二.SolrJ的使用 SolrJ覆盖了solr的全部功能,下面将自己在实际开发中所使用的程序粘贴出来并适当加以解释,由于本人比较菜,代码书写不是那么的精练,还请见谅. 1.  创建solrserver ...

  5. Solr系列一:Solr与Tomcat的整合

    第一次尝试着去写一个系列的教程,希望自己能坚持下去,也希望自己能够通过博客的编写来加深自己对solr搜索的理解. Solr与Tomcat的整合网上有很多教程,我就以我的整合为例来讲述一下我的整合过程, ...

  6. Solr第二讲——SolrJ客户端的使用与案例

    一.Solrj的使用 1.什么是Solrj solrj是访问Solr服务的java客户端(就像通过jedis操作redis一样),提供索引和搜索的请求方法,SolrJ通常在嵌入在业务系统中,通过Sol ...

  7. solr 学习之solrJ

    solrJ是访问Solr服务的JAVA客户端,提供索引和搜索的请求方法,SolrJ通常嵌入在业务系统中,通过solrJ的API接口操作Solr服务. <!-- https://mvnreposi ...

  8. (转)淘淘商城系列——使用solrj来测试索引库

    http://blog.csdn.net/yerenyuan_pku/article/details/72892280 我们使用solrj来操作索引库,一般习惯先建一个单元测试类测试下增删改查方法是否 ...

  9. Solr JAVA客户端SolrJ的使用

    一.Solrj简介 SolrJ是操作Solr的JAVA客户端,它提供了增加.修改.删除.查询Solr索引的JAVA接口.SolrJ针对 Solr提供了Rest 的HTTP接口进行了封装, SolrJ底 ...

随机推荐

  1. 8.Java的特性和优势

    简单性:可以说Java是C++语法的纯净版,没有头文件,没有指针运算,也不用分配内存. 面向对象:是一种程序设计技术,它将重点放在对象以及对象的接口上,模拟人的思维写程序,所以人去学习非常快.因此,J ...

  2. Java框架之SpringMVC 05-拦截器-异常映射-Spring工作流程

    SpringMVC 拦截器 Spring MVC也可以使用拦截器对请求进行拦截处理,可以自定义拦截器来实现特定的功能,自定义的拦截器可以实现HandlerInterceptor接口中的三个方法,也可以 ...

  3. python函数和lambda表达式学习笔记

    1. python函数 不同于其他语言,python支持函数返回多个值 为函数提供说明文档:help(函数名)或者函数名.__doc__ def str_max(str1, str2): ''' 比较 ...

  4. CF6B President's Office 题解

    看到大致思路一致的题解,决定发一篇运用STL不用dfs的题解     好久不发题解,心里不爽 思路: 1.输入的同时找到总统桌子的位置,用vector<pair <int,int> ...

  5. TCP客户端服务器编程模型

    1.客户端调用序列 客户端编程序列如下: 调用socket函数创建套接字 调用connect连接服务器端 调用I/O函数(read/write)与服务器端通讯 调用close关闭套接字 2.服务器端调 ...

  6. MVC (jsp + servlet + javabean) 以及jdbc

    前端: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncod ...

  7. .net core3.1 web api中使用newtonsoft替换掉默认的json序列化组件

    在微软的文档中,有着较为详细的替换教程 https://docs.microsoft.com/zh-cn/aspnet/core/web-api/advanced/formatting?view=as ...

  8. 乌班图14更新软件提示错误:https://mirrors.aliyun.com kubernetes-xenial InRelease: 由于没有公钥,无法验证下列签名: NO_PUBKEY 6A030B21BA07F4FB

    提示如下 获取: https://mirrors.aliyun.com kubernetes-xenial InRelease 忽略 https://mirrors.aliyun.com kubern ...

  9. 按照相应的格式获取系统时间并将其转化为SQL中匹配的(date)时间格式

    在获取时间时需要对时间格式进行设置,此时就需要用到SimpleDateFormat 类 SimpleDateFormat df = new SimpleDateFormat("yyyy-MM ...

  10. Vue methods,watch,computed的区别

    1. computed(计算属性) 计算属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算.注意,如果某个依赖 (比如非响应式属性) 在该实例范畴之外,则计算属性是不会被更新的. eg: < ...