SolrSelectTest 查询与删除 
package com.snow.solr;

import com.snow.bean.Product;
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrServer;
import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.impl.HttpSolrServer;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.common.SolrDocument;
import org.apache.solr.common.SolrDocumentList;
import org.junit.Test; import java.util.ArrayList;
import java.util.List;
import java.util.Map; public class SolrSelectTest { public SolrServer solrServer = new HttpSolrServer("http://localhost:8983/solr/collection1"); //1. solr的基本查询
@Test
public void baseQueryToSolr() throws SolrServerException {
//1. 创建solrServer对象
// SolrServer solrServer = new HttpSolrServer("http://localhost:8983/solr/collection1"); //2. 执行查询: *:* 查询全部
SolrQuery solrQuery = new SolrQuery("华为"); QueryResponse response = solrServer.query(solrQuery); //3. 解析response
SolrDocumentList documents = response.getResults(); for (SolrDocument document : documents) { Object id = document.get("id");
Object title = document.get("title");
Object content = document.get("content");
System.out.println(id+" "+title+" "+content+" "); }
} //1.查询后返回javaBean
@Test
public void javaBeanQueryToSolr() throws SolrServerException {
//1. 创建solrServer对象
// SolrServer solrServer = new HttpSolrServer("http://localhost:8983/solr/collection1"); //2. 执行查询: *:* 查询全部
SolrQuery solrQuery = new SolrQuery("*:*"); QueryResponse response = solrServer.query(solrQuery); //3. 解析response
List<Product> list = response.getBeans(Product.class); for (Product product : list) {
System.out.println(product.toString());
}
} // solr的复杂查询:
// 提取一个公共的查询方法
public void baseQuery(SolrQuery solrQuery) throws SolrServerException {
//1. 创建solrServer对象
// SolrServer solrServer = new HttpSolrServer("http://localhost:8080/solr/collection1"); //2. 执行查询: *:* 查询全部 QueryResponse response = solrServer.query(solrQuery); //3. 解析response
SolrDocumentList documents = response.getResults();
System.out.println(documents.size()); List<Product> list = response.getBeans(Product.class); for (Product product : list) {
System.out.println(product);
}
} //1. 通配符查询: ? *
// ? 表示一个字符
// * 表示多个字符(0到多个)
@Test
public void wildCardQueryToSolr() throws SolrServerException {
SolrQuery solrQuery = new SolrQuery("name:HUAWEI"); solrQuery.setRows(20);//显示多少条数据
baseQuery(solrQuery);
} //2. 布尔查询
@Test
public void booleanQueryToSolr() throws SolrServerException {
//2. 执行查询:
/**
* 1.布尔查询:
* AND OR NOT:
* AND : MUST
* OR: SHOULD
* NOT : MUST_NOT
*/
SolrQuery solrQuery = new SolrQuery("content:lucene OR name:iPhone"); solrQuery.setRows(20);//显示多少条数据
baseQuery(solrQuery); }
//3. 子表达式查询
@Test
public void expressionQueryToSolr() throws SolrServerException {
//表达式查询: (条件1 [or and not] 条件2 ) [and or not] (条件1 [or and not] 条件2)
SolrQuery solrQuery = new SolrQuery("(content:lucene NOT name:iPhone) or name:HUAWEI"); solrQuery.setRows(20);//显示多少条数据
baseQuery(solrQuery);
} //4. 相识度查询
@Test
public void fuzzQueryToSolr() throws SolrServerException {
//相识度查询: ~
// 格式: 字段名称: 字段值~ 表示最大编辑2次
// 字段名称: 字段值~1 表示最大编辑1次
SolrQuery solrQuery = new SolrQuery("name:HUAW~2"); solrQuery.setRows(20);//显示多少条数据
baseQuery(solrQuery);
} //5. 范围查询
@Test
public void rangeQueryToSolr() throws SolrServerException {
//范围查询: 支持数值 日期 文本
// 格式 [ 开始 TO 结束 ] 包含边界值
SolrQuery solrQuery = new SolrQuery("id:[0 TO 1]"); solrQuery.setRows(20);//显示多少条数据
baseQuery(solrQuery); } //6. solr的排序
@Test
public void sortQueryToSolr() throws SolrServerException {
SolrQuery solrQuery = new SolrQuery("*:*");
//设置排序:
// 参数1 指定排序的字段 参数2: 排序方式 asc 和 desc
SolrQuery.SortClause sortClause = new SolrQuery.SortClause("price", "desc");
SolrQuery.SortClause sortClause2 = new SolrQuery.SortClause("id", "desc"); List<SolrQuery.SortClause> list = new ArrayList<SolrQuery.SortClause>();
list.add(sortClause);
list.add(sortClause2);
/**
* 多个排序
*/
solrQuery.setSorts(list);
/**
* 单个排序
*/
//solrQuery.setSort("id", SolrQuery.ORDER.desc); solrQuery.setRows(20);//显示多少条数据
baseQuery(solrQuery);
} //7. solr的分页
@Test
public void limitQueryToSolr() throws SolrServerException {
//定义两个参数
int page = 1;//当前页
int pageSize = 1; //每页的条数 SolrQuery solrQuery = new SolrQuery("*:*");
solrQuery.setStart((page-1)*pageSize);
solrQuery.setRows(pageSize);//显示多少条数据
baseQuery(solrQuery);
} //8. solr的高亮
@Test
public void highlighterQueryToSolr() throws SolrServerException {
//1. 创建solrServer对象
// SolrServer solrServer = new HttpSolrServer("http://localhost:8080/solr/collection1"); //定义两个参数
int page = 1;//当前页
int pageSize = 3; //每页的条数 SolrQuery solrQuery = new SolrQuery("title:贵 OR name:HUAW~2"); //设置高亮------开始
solrQuery.setHighlight(true);
solrQuery.addHighlightField("title");
solrQuery.addHighlightField("name");
solrQuery.setHighlightSimplePre("<font color='red'>");
solrQuery.setHighlightSimplePost("</font>");
solrQuery.setHighlightSnippets(10); //设置最大的分片数,默认为1, 主要针对如果是多字段的情况
//设置高亮------结束
solrQuery.setStart((page-1)*pageSize);
solrQuery.setRows(pageSize);//显示多少条数据 QueryResponse response = solrServer.query(solrQuery);
//获取高亮的集合
Map<String, Map<String, List<String>>> highlighting = response.getHighlighting(); for (String docID : highlighting.keySet()) {
//获取对应文档的高亮集合
Map<String, List<String>> map = highlighting.get(docID); List<String> list = map.get("name");
if (list != null) {
System.out.println("list的长度"+list.size()); System.out.println("高亮内容"+list.get(0));
}
list = map.get("title");
if (list != null) {
System.out.println("list的长度"+list.size()); System.out.println("高亮内容"+list.get(0));
}
}
} }

  

SolrSaveDelete 保存于删除
package com.snow.solr;

import com.snow.bean.Product;
import org.apache.solr.client.solrj.SolrServer;
import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.impl.HttpSolrServer;
import org.apache.solr.common.SolrInputDocument;
import org.junit.Test; import java.io.IOException;
import java.util.ArrayList;
import java.util.List; public class SolrSaveDelete { public SolrServer solrServer = new HttpSolrServer("http://localhost:8983/solr/collection1"); //1. solr的基础入门案例
@Test
public void createIndexToSolr() throws IOException, SolrServerException { //1. 创建solrj对象
// SolrServer solrServer = new HttpSolrServer("http://localhost:8983/solr/collection1"); //2.1 添加document对象(此处为solr的document)
SolrInputDocument doc = new SolrInputDocument(); doc.addField("id","1");
doc.addField("content","我是一个中国人, 我喜欢我们的国家");
doc.addField("title","简介"); //2. 进行索引的添加
solrServer.add(doc);
//3. 提交索引
solrServer.commit();
} //2. 写入多条索引
@Test
public void createManyIndexToSolr() throws IOException, SolrServerException {
//1. 创建solrServer对象
// SolrServer solrServer = new HttpSolrServer("http://localhost:8983/solr/collection1");
//2.1 设置多条数据
List<SolrInputDocument> docs = new ArrayList<SolrInputDocument>();
for(int i=0 ; i<10 ; i++){
//2.1.1 创建一个document
SolrInputDocument document = new SolrInputDocument();
document.addField("id",i);
document.addField("content","solr是一个独立的企业级搜索应用服务器, 可以通过http请求访问这个服务器, 获取或者写入对应的内容, 其底层是Lucene "+i);
document.addField("title","solr的简介"); //2.1.2 将document添加到集合中
docs.add(document);
} //2. 写入索引
solrServer.add(docs); //3. 提交索引
solrServer.commit();
} //3. 通过javaBean向solr写入索引
@Test
public void createIndexJavaBeanToSolr() throws IOException, SolrServerException {
//1. 创建solrServer对象
SolrServer solrServer = new HttpSolrServer("http://localhost:8983/solr/collection1");
//2.1 创建product对象, 写入索引
Product product = new Product();
product.setId("11");
product.setName("HUAWEI Mate 20");
product.setBrand("华为");
product.setPrice(4999.0F);
product.setTitle("亮瞎你的双眼,没办法就是好用");
//2. 写入索引
solrServer.addBean(product);
//3. 提交索引
solrServer.commit(); } //4. 删除索引的操作
//修改的操作这里不演示, 当id相同就是修改, id不同就是添加
@Test
public void deleteIndexToSolr() throws IOException, SolrServerException {
//1. 创建solrServer对象
// SolrServer solrServer = new HttpSolrServer("http://localhost:8983/solr/collection1");
//2. 执行删除
//solrServer.deleteById("10"); //通过id删除, 可以传递一 个id , 也可以传递一个ids数组进行删除
// 条件的基本格式: 字段名称:字段值
solrServer.deleteByQuery("*:*"); //根据条件删除 *:* 删除全部
//3.执行提交
solrServer.commit();
} }
        <dependency>
<groupId>org.apache.solr</groupId>
<artifactId>solr-solrj</artifactId>
<version>4.10.2</version>
</dependency>
<!--日志的包, solrj执行需要一个日志包-->
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging-api</artifactId>
<version>1.1</version>
</dependency>
</dependencies>

Lucene与Solr基础的更多相关文章

  1. lucene和solr

    我们为什么要用solr呢? 1.solr已经将整个索引操作功能封装好了的搜索引擎系统(企业级搜索引擎产品) 2.solr可以部署到单独的服务器上(WEB服务),它可以提供服务,我们的业务系统就只要发送 ...

  2. 使用 Apache Lucene 和 Solr 4 实现下一代搜索和分析

    使用 Apache Lucene 和 Solr 4 实现下一代搜索和分析 使用搜索引擎计数构建快速.高效和可扩展的数据驱动应用程序 Apache Lucene™ 和 Solr™ 是强大的开源搜索技术, ...

  3. 开源搜素引擎:Lucene、Solr、Elasticsearch、Sphinx优劣势比较

    https://blog.csdn.net/belalds/article/details/82667692 开源搜索引擎分类 1.Lucene系搜索引擎,java开发,包括: Lucene Solr ...

  4. 全文索引-lucene,solr,nutch,hadoop之nutch与hadoop

    全文索引-lucene.solr.nutch,hadoop之lucene 全文索引-lucene.solr,nutch,hadoop之solr 我在去年的时候,就想把lucene,solr.nutch ...

  5. 【solr基础教程之一】Solr相关知识点串讲

           Solr是Apache Lucene的一个子项目.Lucene为全文搜索功能提供了完备的API,但它只作为一个API库存在,而不能直接用于搜索.因此,Solr基于Lucene构建了一个完 ...

  6. Solr学习之二-Solr基础知识

    一 基本说明 简单来说Solr是基于Lucene的高性能的,开源的Java企业搜索服务器.Solr可以看作一个Web app,运行在tomcat或Jetty这类HTTP服务器上, 底层是一个基于Luc ...

  7. lucene、solr中的日期衰减方法-------function query --尚未测试在solr4.8

    经常有一种情景是这样的:我们索引了N年的文章,而查询时候无论直接用相关度.或者用时间排序,都是比较鲁莽的:我们想要一种既要相关度比较高,又要时间上比较新的文章. 这时候的解决办法就是,自定义日期衰减的 ...

  8. 【solr基础教程之中的一个】Solr相关知识点串讲

           Solr是Apache Lucene的一个子项目.Lucene为全文搜索功能提供了完备的API.但它仅仅作为一个API库存在.而不能直接用于搜索. 因此,Solr基于Lucene构建了一 ...

  9. Solr基础知识二(导入数据)

    上一篇讲述了solr的安装启动过程,这一篇讲述如何导入数据到solr里. 一.准备数据 1.1 学生相关表 创建学生表.学生专业关联表.专业表.学生行业关联表.行业表.基础信息表,并创建一条小白的信息 ...

随机推荐

  1. 将linux系统目录挂载到其他分区,扩大系统可用空间

    刚看到有小白用户说linux系统盘分区太小,不够用,问是不是要重装系统? 其实是不需要重装系统的,可以考虑把一些系统目录挂载到单独的分区. 比如将用户目录 /home 挂载到单独的分区: 1.首先打开 ...

  2. 00-JAVA语法基础--动手动脑

    1.运行EnumTest.java,并分析结果,得出结论. 其源代码以及运行结果截图如下: 枚举类型的常量以字符串的形式顺序储.源代码中s和t不是原始数据类型.getCLass():取得当前对象所属的 ...

  3. MAVEN 加载公共包 commons

    <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileu ...

  4. 有关python 函数参数

    # def foo(x):# print(x)### foo(1)# foo('a')# foo({'a':2}) #形参与实参:# def foo(x,y): #x=1,y=2# return x+ ...

  5. 机器学习模型从windows下 spring上传到预发布会导致模型不可加载

    1.通过上传到redis,程序通过redis拉取模型,解决问题. 2.问题原因初步思考为windows下模型文件上传到 linux导致,待继续跟进查找.

  6. SSH(Spring SpringMVC Hibernate)框架整合

    项目说明: 使用SSH(Spring SpringMVC Hibernate)框架整合添加部门功能 项目结构   1.导入依赖jar包 <!--单测--> <dependency&g ...

  7. 什么是C++

    1.到底什么是C++ C++是一门面向对象的程序设计语言. 关键词:程序设计语言,面向对象 程序设计语言是用来书写计算机程序的语言,更形象的说,程序设计语言是用来和计算机“交流的语言.” 面向对象(o ...

  8. 烧写树莓派系统,SSH配置,无屏登录流程

    首先去 https://downloads.raspberrypi.org/raspbian/images/ 下载需要的版本镜像 我这里下载 https://downloads.raspberrypi ...

  9. 02-CSS&JS

    今日目标 使用CSS完成网站首页的优化 使用CSS完成网站注册页面的优化 使用JS完成简单的数据校验 使用JS完成图片轮播效果 教学目标: - 了解CSS的概念 - 了解CSS的引入方式 - 了解CS ...

  10. python字符串面试题:找出一个字符串中第一个字母和最后一个字符是第一次重复,中间没有重复且最长的子串

    1.给出任意一个字符串,打印一个最长子串字符串及其长度,如果有相同长度的子字符串,都要一起打印出来,该子字符串满足以下条件, 第一个字母和最后一个字符是第一次重复 这个子字符串的中间字母没有重复 这个 ...