zoukankan      html  css  js  c++  java
  • 分享知识-快乐自己:java代码 操作 solr

    POM 文件:

    <!-- solr客户端 -->
    <dependency>
            <groupId>org.apache.solr</groupId>
            <artifactId>solr-solrj</artifactId>
            <version>4.10.3</version>
    </dependency> 

    JAVA 代码:

    package com.gdbd.solrj;
    
    import org.apache.solr.client.solrj.SolrQuery;
    import org.apache.solr.client.solrj.SolrServer;
    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.apache.solr.common.SolrInputDocument;
    
    import java.util.List;
    import java.util.Map;
    import java.util.Scanner;
    
    /**
     * @Description: SolrJ 添加数据测试类
     * @Author: DGBD
     * @CreateDate: 2018/12/31 15:57
     * @UpdateUser: yc
     * @UpdateDate: 2018/12/31 15:57
     * @UpdateRemark: 修改内容
     * @博客地址: https://www.cnblogs.com/mlq2017/
     * @Version: 1.0
     */
    public class TestSolrJ {
    
        public static void main(String[] args) {
            try {
                do {
                    System.out.println("....请选择你的操作....");
                    System.out.println("1):向 solr 索引库添加数据");
                    System.out.println("2):查询 solr 索引库数据");
                    System.out.println("3):修改 solr 索引库数据");
                    System.out.println("4):删除 solr 索引库数据");
                    System.out.println("5):根据 查询 删除 solr 索引库数据");
                    System.out.println("请输入....");
                    Scanner input = new Scanner(System.in);
                    int num = input.nextInt();
                    switch (num) {
                        case 1:
                            testAddDocument();
                            break;
                        case 2:
                            testselDocument();
                            break;
                        case 3:
                            break;
                        case 4:
                            testdelDocument();
                            break;
                        case 5:
                            testdelQueryDocument();
                            break;
                    }
                } while (true);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    
        /***
         * 向 solr 索引库添加数据
         * @throws Exception
         */
        public static void testAddDocument() throws Exception {
            //01、创建一个 SolrServer 对象。创建一个 HTTPSolrServer对象。需要指定 solr 服务的 url
            SolrServer solrServer = new HttpSolrServer("http://192.168.31.206:8080/solr/collection1");
            //02、创建一个文档对象SolrInputDocument
            SolrInputDocument document = new SolrInputDocument();
            //03、向文档中添加域,必须有 id 域,域的名称必须在 schema.xml
            document.addField("id", "123");
            document.addField("item_title", "测试商品标题2");
            document.addField("item_sell_point", "测试商品买点2");
            document.addField("item_price", 1000);
            document.addField("item_image", "测试商品图片2");
            document.addField("item_category_name", "测试商品分类名称2");
            document.addField("item_desc", "测试商品描述2");
            SolrInputDocument document1 = new SolrInputDocument();
            //03、向文档中添加域,必须有 id 域,域的名称必须在 schema.xml
            document1.addField("id", "test001");
            document1.addField("item_title", "测试商品标题1");
            document1.addField("item_sell_point", "测试商品买点1");
            document1.addField("item_price", 1000);
            document1.addField("item_image", "测试商品图片1");
            document1.addField("item_category_name", "测试商品分类名称1");
            document1.addField("item_desc", "测试商品描述1");
            //04、把文档对象写入索引库
            solrServer.add(document);
            solrServer.add(document1);
            solrServer.commit();
            System.out.println("成功插入...............................");
        }
    
        /***
         * 查询 solr 索引库数据
         *
         * 提示:查询所有(*:*)不能设置高亮显示
         *       分页不设置默认为(0-10)
         *       如果查询条件上没有指定在哪一个 业务域上搜索 则在默认搜索域中搜索
         *
         * @throws Exception
         */
        public static void testselDocument() throws Exception {
            //01、创建一个 SolrServer 对象。创建一个 HTTPSolrServer对象。需要指定 solr 服务的 url
            SolrServer solrServer = new HttpSolrServer("http://192.168.31.206:8080/solr/collection1");
            //02、创建一个 solrQuery 查询对象
            SolrQuery solrQuery = new SolrQuery();
            //设置查询条件:过滤条件、分页条件...
            solrQuery.set("q", "手机");
            //solrQuery.setQuery("*:*");
    
            //分页条件(从第 30 条开始查询,每页显示10 条)
            solrQuery.set("start", 0);//solrQuery.setStart();
            solrQuery.set("rows", 5);//solrQuery.setRows();
    
            //默认搜索域
            solrQuery.set("df", "item_keywords");
    
            //设置高亮
            solrQuery.set("hl", true);//solrQuery.setHighlight(true);
    
            //设置高亮显示域(对哪一个域进行 高亮显示:这里设置标题域为高亮)
            solrQuery.set("hl.fl", "item_title");//solrQuery.addHighlightField("item_title");
    
            //高亮显示前缀后缀
            solrQuery.set("hl.simple.pre", "<em>");//solrQuery.setHighlightSimplePre("<em>");
            solrQuery.set("hl.simple.post", "</em>");//solrQuery.setHighlightSimplePost("</em>");
    
            //03、执行查询(得到一个 Response 对象)
            QueryResponse response = solrServer.query(solrQuery);
            //04、取查询结果
            SolrDocumentList results = response.getResults();
            //05、取查询总记录数
            System.out.println("取查询总记录数:>>>>" + results.getNumFound());
            for (SolrDocument item : results) {
                System.out.println(item.get("id"));
                //06、取高亮显示
                Map<String, Map<String, List<String>>> highlighting = response.getHighlighting();
                List<String> list = highlighting.get(item.get("id")).get("item_title");
                String title = "";
                if (list != null && list.size() > 0) {
                    title = list.get(0);//获取高亮的信息
                } else {
                    title = (String) item.get("item_title");//没有高亮信息 则显示默认的
                }
                System.out.println(title);
                System.out.println(item.get("item_sell_point"));
                System.out.println(item.get("item_price"));
                System.out.println(item.get("item_image"));
                System.out.println(item.get("item_category_name"));
                System.out.println(item.get("item_desc"));
                System.out.println("===========================================");
            }
    
    
        }
    
        /***
         * 修改 solr 索引库数据
         * @throws Exception
         */
        public static void testmodfyDocument() throws Exception {
    
        }
    
        /***
         * 根据 Id 删除 solr 索引库数据
         * @throws Exception
         */
        public static void testdelDocument() throws Exception {
            //01、创建一个 SolrServer 对象。创建一个 HTTPSolrServer对象。需要指定 solr 服务的 url
            SolrServer solrServer = new HttpSolrServer("http://192.168.31.206:8080/solr/collection1");
            //根据 Id 删除 solr 中的数据
            solrServer.deleteById("test001");
            solrServer.commit();
        }
    
        /***
         * 根据 查询 删除 solr 索引库数据
         * @throws Exception
         */
        public static void testdelQueryDocument() throws Exception {
            //01、创建一个 SolrServer 对象。创建一个 HTTPSolrServer对象。需要指定 solr 服务的 url
            SolrServer solrServer = new HttpSolrServer("http://192.168.31.206:8080/solr/collection1");
            //根据 Id 删除 solr 中的数据
            solrServer.deleteByQuery("*:*");
            solrServer.commit();
        }
    }

    ===========配置文件:

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:context="http://www.springframework.org/schema/context"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-4.2.xsd
    ">
    
        <!--扫描-->
        <context:component-scan base-package="com.gdbd"/>
    
        <!--配置单机版solr的连接-->
        <bean id="httpSolrServer" class="org.apache.solr.client.solrj.impl.HttpSolrClient">
            <constructor-arg name="baseURL" value="http://192.168.31.212:8080/solr/collection1"/>
        </bean>
    
        <!--配置集群版solr的连接-->
        <bean id="cloudSolrServer" class="org.apache.solr.client.solrj.impl.CloudSolrClient">
            <constructor-arg name="zkHost" value="192.168.31.209:2181,192.168.209:2182,192.168.31.209:2183"/>
            <property name="defaultCollection" value="collection2"/>
        </bean>
    
    </beans>

    pojo: 

    package com.gdbd.pojo;
    
    import com.fasterxml.jackson.annotation.JsonSubTypes;
    import org.apache.solr.client.solrj.beans.Field;
    
    /**
     * @Description: 测试类
     * @Author: DGBD
     * @CreateDate: 2019/1/10 10:04
     * @UpdateUser: yc
     * @UpdateDate: 2019/1/10 10:04
     * @UpdateRemark: 修改内容
     * @博客地址: https://www.cnblogs.com/mlq2017/
     * @Version: 1.0
     */
    public class Passage {
    
        // 用于标明solr索引的id,需要放在字段上
        @Field("id")
        private String id;
        @Field("content")
        private String content;
        @Field("name")
        private String name;
        @Field("title")
        private String title;
    
        public String getId() {
            return id;
        }
    
        public void setId(String id) {
            this.id = id;
        }
    
        .......
    }

    注解单机版操作:

    package com.gdbd.solr;
    
    import com.gdbd.pojo.Passage;
    import org.apache.solr.client.solrj.SolrQuery;
    import org.apache.solr.client.solrj.SolrServerException;
    import org.apache.solr.client.solrj.impl.HttpSolrClient;
    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.util.NamedList;
    import org.junit.After;
    import org.junit.Before;
    import org.junit.Test;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    import java.io.IOException;
    import java.util.List;
    import java.util.Map;
    
    /**
     * @Description: solr 单机测试类
     * @Author: DGBD
     * @CreateDate: 2019/1/10 10:14
     * @UpdateUser: yc
     * @UpdateDate: 2019/1/10 10:14
     * @UpdateRemark: 修改内容
     * @博客地址: https://www.cnblogs.com/mlq2017/
     * @Version: 1.0
     */
    public class SolrTest {
    
        private HttpSolrClient solrServer = null;
    
        @Before
        public void before() {
            //加载配置文件
            ApplicationContext context =
                    new ClassPathXmlApplicationContext("spring-solr.xml");
            //获取对象
            solrServer = (HttpSolrClient) context.getBean("httpSolrServer");
        }
    
        /***
         * 添加信息
         * @throws IOException
         * @throws SolrServerException
         */
        @Test
        public void demo() throws IOException, SolrServerException {
            for (int i = 0; i < 5; i++) {
                //伪造添加的信息
                Passage passage = new Passage("456" + i, "测试数据" + i, "MLQ" + i, "你好不好" + i);
                //向solr中添加数据
                solrServer.addBean(passage);
            }
            //提交
            solrServer.commit();
        }
    
        /***
         * 查询数据
         */
        @Test
        public void sel() throws IOException, SolrServerException {
            //创建一个 solrQuery 查询对象
            SolrQuery solrQuery = new SolrQuery();
            //设置查询条件:过滤条件、分页条件...
            solrQuery.setQuery("name:MLQ");
            /***
             * 分页条件(从第 30 条开始查询,每页显示10 条)
             * solrQuery.setStart();olrQuery.setRows();
             */
            solrQuery.set("start", 0);
            solrQuery.set("rows", 5);
            //默认搜索域
            solrQuery.set("df", "name");
            /***
             * 设置开启高亮
             * solrQuery.setHighlight(true);
             */
            solrQuery.set("hl", true);
            /***
             * 设置高亮显示域(对哪一个域进行 高亮显示:这里设置标题域为高亮)
             * solrQuery.addHighlightField("item_title");
             */
            solrQuery.set("hl.fl", "name");
    
            /***
             * 高亮显示前缀后缀
             * solrQuery.setHighlightSimplePre("<em>");
             * solrQuery.setHighlightSimplePost("</em>");
             */
            solrQuery.set("hl.simple.pre", "<em>");
            solrQuery.set("hl.simple.post", "</em>");
    
            //执行查询(得到一个 Response 对象)
            QueryResponse response = solrServer.query(solrQuery);
            //取查询结果
            SolrDocumentList results = response.getResults();
            //取查询总记录数
            System.out.println("取查询总记录数:>>>>" + results.getNumFound());
            for (SolrDocument item : results) {
                System.out.println("id--->" + item.get("id"));
                //06、取高亮显示
                String name = null;
                Map<String, Map<String, List<String>>> highlighting = response.getHighlighting();
                List<String> list = highlighting.get(item.get("id")).get("name");
                if (list != null && list.size() > 0) {
                    name = list.get(0);//获取高亮的信息
                } else {
                    name = (String) item.get("name");//没有高亮信息 则显示默认的
                }
                System.out.println("name--->" +name);
                System.out.println("content--->" + item.get("content"));
                System.out.println("title--->" + item.get("title"));
                System.out.println("===========================================");
            }
        }
        /***
         * 删除所有数据
         * @throws Exception
         */
        @Test
        public void testdelQueryDocument() throws Exception {
            solrServer.deleteByQuery("*:*");
            solrServer.commit();
        }
        @After
        public void after() throws IOException {
            solrServer.close();
        }
    }

    注解集群版操作:

    package com.gdbd.solr;
    
    import com.gdbd.pojo.Passage;
    import org.apache.solr.client.solrj.SolrServerException;
    import org.apache.solr.client.solrj.impl.CloudSolrClient;
    import org.junit.After;
    import org.junit.Before;
    import org.junit.Test;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    
    import java.io.IOException;
    
    /**
     * @Description: solr 集群测试
     * @Author: DGBD
     * @CreateDate: 2019/1/11 8:45
     * @UpdateUser: yc
     * @UpdateDate: 2019/1/11 8:45
     * @UpdateRemark: 修改内容
     * @博客地址: https://www.cnblogs.com/mlq2017/
     * @Version: 1.0
     */
    public class SolrCloudTest {
    
        private CloudSolrClient solrServer = null;
    
        @Before
        public void before() {
            //加载配置文件
            ApplicationContext context =
                    new ClassPathXmlApplicationContext("spring-solr.xml");
            //获取对象
            solrServer = (CloudSolrClient) context.getBean("cloudSolrServer");
        }
        @Test
        public void demo() throws IOException, SolrServerException {
            /***
             * 创建cloudSolrServer,构造方法中指定zookeeper的地址列表
             * CloudSolrServer solrServer = new CloudSolrServer("192.168.55.3:2181,192.168.55.3:2182,192.168.55.3:2183");
             * 需要设置默认collection
             * solrServer.setDefaultCollection("collection2");
             */
            //伪造添加的信息
            for (int i = 0; i < 5; i++) {
                //伪造添加的信息
                Passage passage = new Passage("456" + i, "测试数据" + i, "MLQ" + i, "你好不好" + i);
                //向solr中添加数据
                solrServer.addBean(passage);
            }
            //提交
            solrServer.commit();
        }
    
        /***
         * 删除所有数据
         * @throws Exception
         */
        @Test
        public void testdelQueryDocument() throws Exception {
            solrServer.deleteByQuery("*:*");
            solrServer.commit();
        }
    
        @After
        public void after() throws IOException {
            solrServer.close();
        }
    }
  • 相关阅读:
    npm ERR! shasum check failed for
    使用js闭包封装一个原生的模态框
    使用weexplus + vue开发APP的填坑之旅
    weex 中出现 loading无法关闭
    weex create test-app Error: Cannot find module '../package.json'
    flutter 填坑之旅(dart学习笔记篇)
    各种版本的Linux 镜像下载网址
    在vue 项目中嵌入jsp页面
    mahout 推荐引擎的相关介绍,理解,如何应用。(2)
    mahout 推荐引擎的相关介绍,理解,如何应用。(1)
  • 原文地址:https://www.cnblogs.com/mlq2017/p/10204824.html
Copyright © 2011-2022 走看看