所需的包如图:

代码如下:
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搜索引擎的增删查改的更多相关文章

  1. java实现简单的数据库的增删查改,并布局交互界面

        一.系统简介 1.1.简介  本系统提供了学生信息管理中常见的基本功能,主要包括管理员.管理员的主要功能有对学生信息进行增加.删除.修改.查找等操作,对信息进行管理,对信息进行修改.查找等操作 ...

  2. 分享知识-快乐自己:java代码 操作 solr

    POM 文件: <!-- solr客户端 --> <dependency> <groupId>org.apache.solr</groupId> < ...

  3. go语言操作mysql范例(增删查改)

    http://blog.csdn.net/jesseyoung/article/details/40398321 go语言连接mysql简介    go官方仅提供了database package,d ...

  4. Moogoose操作之Schema实现增删查改

    Schema不仅定义了文档结构和使用性能,可以为后面的Model和Entity提供公共的属性和方法. Schema.Model.Entity的关系: Schema : 可以定义字段类型,不具备数据库的 ...

  5. SSH2 增删查改实例

    (一)引入包 (共73个,不一定都需要,但是我的项目是这么多,经过调试,没有包冲突) (二)创建数据库表 建立数据库octtest,并创建user表,表里面一共4个字段:id,姓,名,年龄. 语句如下 ...

  6. Java连接MySQL数据库及简单的增删查改操作

    主要摘自 https://www.cnblogs.com/town123/p/8336244.html https://www.runoob.com/java/java-mysql-connect.h ...

  7. SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)

    SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)-DML 1.SQL INSERT INTO 语句(在表中插入) INSERT INTO 语句用于向表中插入新记录. SQL I ...

  8. SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码)

    SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码) 概述: 表由行和列组成,每个表都必须有个表名. SQL CREATE TABLE 语法 CREATE TABLE tabl ...

  9. java中CRUD(增删查改)底层代码的实现

    java中CRUD(增删查改)底层代码的实现: package com.station.dao; import com.station.model.Product; import java.sql.* ...

随机推荐

  1. [HDFS Manual] CH1 HDFS体系结构

    v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:url(#default#VM ...

  2. jinfo

    jinfo是jdk自带的命令,用来查看.修改jvm的配置参数. [weblogic@host bin]$ jinfo-bash: jinfo: command not found[weblogic@h ...

  3. idea checkout 项目

    1. 2.添加一个连接 选择远程目录checkout  , 然后选择本地目录   但是这样会创建一个新的projectwindow  如果要创建为module的话  1.手动引入从svn check的 ...

  4. C#函数的默认参数——填坑记

    昨天踩了一个坑.默认参数 + 增量发布的坑. 过程是这样的. 1. 有一个底层的方法,格式形如 void Test<T>(int p1, string p2, Func<T> ...

  5. VMware Workstation 14.1.1 精简特别版

    VMware Workstation 精简特别版,由卡饭网友のcuiplay精简制作,集成许可证密钥安装即永久激活,该特别版最大特色可安装MAC OS X客户操作系统,此外添加了DELL SLIC 2 ...

  6. Java源码阅读的真实体会(一种学习思路)

    Java源码阅读的真实体会(一种学习思路) 刚才在论坛不经意间,看到有关源码阅读的帖子.回想自己前几年,阅读源码那种兴奋和成就感(1),不禁又有一种激动. 源码阅读,我觉得最核心有三点:技术基础+强烈 ...

  7. 解决stackoverflow打开慢的问题

    Stack Overflow是国外一个与程序相关的IT技术问答网站.类似于国内的segmentfault.程序员们对于这2个网站应该都不陌生.但是我们打开stackoverflow的时候,会发现打开速 ...

  8. Netty:option和childOption参数设置说明

    Channel配置参数 (1).通用参数 CONNECT_TIMEOUT_MILLIS :   Netty参数,连接超时毫秒数,默认值30000毫秒即30秒. MAX_MESSAGES_PER_REA ...

  9. HAWQ配置之HDFS HA

    一.在ambari管理界面启用HDFS HA 在ambari中这步很简单,在所有安装的服务都正常之后,在HDFS的服务界面中,点击下拉菜单“Actions”,选择启用HDFS HA项 “Enable ...

  10. Qt OpenGL 鼠标拾取实现

    在之前的文章中讲到了OpenGL鼠标拾取操作的例子,工作中需要在Qt中实现,下面的程序演示了QT中opengl的拾取例子. 本例子在Qt5.12和Qt Creator4.8.0上测试,使用的是QOpe ...