java代码操作solr搜索引擎的增删查改
所需的包如图:
代码如下:
package solr;
import java.util.List;
import java.util.Map;
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrQuery.ORDER;
import org.apache.solr.client.solrj.impl.HttpSolrClient;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.client.solrj.response.UpdateResponse;
import org.apache.solr.common.SolrDocument;
import org.apache.solr.common.SolrDocumentList;
import org.apache.solr.common.SolrInputDocument;
import org.junit.Before;
import org.junit.Test;
public class test {
private static final String URL = "http://localhost:8983/solr/test/";
private HttpSolrClient server = null;
/*
* 初始化
*/
@Before
public void init() {
// 创建 server
server = new HttpSolrClient(URL);
}
/*
* 添加、修改索引
*/
@Test
public void addDoc() {
SolrInputDocument doc = new SolrInputDocument();
doc.addField("id", "4");
doc.addField("title", "号外!号外!特别喜讯");
doc.addField("content", "王部长今天把solr关键应用点全部贯通,希望在以后的学习生涯再接再厉。");
try {
//如果不存在,就添加;如果存在,就更改
UpdateResponse response = server.add(doc);
//一定要提交
server.commit();
System.out.println("Query Time :" + response.getQTime());
System.out.println("Elapsed Time :" + response.getElapsedTime());
System.out.println("Status :" + response.getStatus());
} catch (Exception e) {
System.err.print(e);
}
}
/**
* 普通查询
*/
@Test
public void testQuery() {
String queryStr = "content:*";
SolrQuery params = new SolrQuery(queryStr);
params.setSort("id",ORDER.asc);
params.set("rows", 10);
try {
QueryResponse response = null;
response = server.query(params);
SolrDocumentList list = response.getResults();
System.out.println("总共 : " + list.getNumFound() + "条记录");
for (SolrDocument doc : list) {
System.out.println("id : " + doc.get("id") + " title : " + doc.get("title")+
" content : "+ doc.get("content"));
}
} catch (Exception e) {
System.err.print(e);
}
}
/*
* 高亮查询
*/
@Test
public void hightLightQuery() throws Exception{
SolrQuery solrQuery = new SolrQuery();
solrQuery.setQuery("title:新闻");
//solrQuery.setFilterQueries("content:[0 TO 100]");
//solrQuery.setSort("content",ORDER.asc);
// 开启高亮
solrQuery.setHighlight(true).setHighlightSnippets(1); ;
// 设置高亮域
solrQuery.addHighlightField("title");
// 设置高亮前缀
solrQuery.setHighlightSimplePre("<font color='red'>");
// 设置高亮后缀
solrQuery.setHighlightSimplePost("</font>");
QueryResponse queryResponse = server.query(solrQuery);
// 从查询响应中获取结果集
SolrDocumentList solrDocumentList = queryResponse.getResults();
// 打印结果集中的数据
for (SolrDocument solrDocument : solrDocumentList) {
// 获取查询结果
System.out.println( solrDocument.get("content"));
// 获取高亮结果
Map<String, Map<String, List<String>>> map = queryResponse.getHighlighting();
//获取多层嵌套的结果
List<String> lists = map.get(solrDocument.get("id")).get("title");
if(lists != null)
System.out.println(lists.get(0));
}
}
/*
* 删除
*/
@Test
public void deletDoc() throws Exception{
server.deleteByQuery("id:4");
//一定要提交
server.commit();
}
}
java代码操作solr搜索引擎的增删查改的更多相关文章
- java实现简单的数据库的增删查改,并布局交互界面
一.系统简介 1.1.简介 本系统提供了学生信息管理中常见的基本功能,主要包括管理员.管理员的主要功能有对学生信息进行增加.删除.修改.查找等操作,对信息进行管理,对信息进行修改.查找等操作 ...
- 分享知识-快乐自己:java代码 操作 solr
POM 文件: <!-- solr客户端 --> <dependency> <groupId>org.apache.solr</groupId> < ...
- go语言操作mysql范例(增删查改)
http://blog.csdn.net/jesseyoung/article/details/40398321 go语言连接mysql简介 go官方仅提供了database package,d ...
- Moogoose操作之Schema实现增删查改
Schema不仅定义了文档结构和使用性能,可以为后面的Model和Entity提供公共的属性和方法. Schema.Model.Entity的关系: Schema : 可以定义字段类型,不具备数据库的 ...
- SSH2 增删查改实例
(一)引入包 (共73个,不一定都需要,但是我的项目是这么多,经过调试,没有包冲突) (二)创建数据库表 建立数据库octtest,并创建user表,表里面一共4个字段:id,姓,名,年龄. 语句如下 ...
- Java连接MySQL数据库及简单的增删查改操作
主要摘自 https://www.cnblogs.com/town123/p/8336244.html https://www.runoob.com/java/java-mysql-connect.h ...
- SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)
SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)-DML 1.SQL INSERT INTO 语句(在表中插入) INSERT INTO 语句用于向表中插入新记录. SQL I ...
- SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码)
SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码) 概述: 表由行和列组成,每个表都必须有个表名. SQL CREATE TABLE 语法 CREATE TABLE tabl ...
- java中CRUD(增删查改)底层代码的实现
java中CRUD(增删查改)底层代码的实现: package com.station.dao; import com.station.model.Product; import java.sql.* ...
随机推荐
- create-react-app入门教程
Create React App是FaceBook的React团队官方出的一个构建React单页面应用的脚手架工具.它本身集成了Webpack,并配置了一系列内置的loader和默认的npm的脚本,可 ...
- .NET内存泄漏(之 静态事件)
一.事件引起的内存泄露 1.不手动注销事件也不发生内存泄露的情况 我们经常会写EventHandler += AFunction; 如果没有手动注销这个Event handler类似:EventHan ...
- Java多线程系列——从菜鸟到入门
持续更新系列. 参考自Java多线程系列目录(共43篇).<Java并发编程实战>.<实战Java高并发程序设计>.<Java并发编程的艺术>. 基础 Java多线 ...
- mysql的大量的sleep进程解决办法
mysql的大量的sleep进程解决办法 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/liuyong0507/article/detai ...
- 大话前端解析Json对象
一.对于标准的json对象如: var result=[{"flag":1,"macId":"2","mbId":0,& ...
- Elasticsearch index fields 重命名
reindex数据复制,重索引 POST _reindex { "source": { "index": "twitter" }, &quo ...
- SAP PA Document List
RE-Real Estate 房地产 RE010-EN-Col95-Real Estate Processes in SAP ERP RE200-EN-Col95-Real Estate Manage ...
- GLSL数组类型、浮点数Uniform
// 添加shader中的uniform ss->addUniform(new osg::Uniform("test1", false)); //设置shader中的unif ...
- Sublime Text 插件之HTML-CSS-JS Prettify—格式化HTML CSS JS与显示函数列表
插件名称:HTML-CSS-JS Prettify 安装步骤: 1.ctrl + shift + p 打开控制台2.输入install package,选择install package(如果已经安装 ...
- 面试准备——(三)Selenium(1)基础问题及自动化测试
转载:https://www.cnblogs.com/lesleysbw/p/6413880.html 面试准备——(三)Selenium(1)基础问题及自动化测试 滴滴面试: 1. 自己负责哪部 ...