solrJ的使用

1、单机版solrj的使用:

public class SolrTest {
    
    /**
     * solr的增加或修改
     * @throws IOException 
     */
    @Test
    public void test1() throws Exception {
        //创建连接
        SolrServer solrService = new HttpSolrServer("http://localhost:8080/solr");
        //创建solr文档对象
        SolrInputDocument doc = new SolrInputDocument();
        //创建域
        doc.setField("id", "z001");
        doc.setField("product_name", "小米手机");
        doc.setField("product_price", "100");
        doc.setField("product_catalog_name", "发烧的手机");
        solrService.add(doc);
        solrService.commit();
    }
    
    /**
     * 删除数据
     */
    @Test
    public void test2() throws Exception {
        SolrServer solrService = new HttpSolrServer("http://localhost:8080/solr");
        solrService.deleteByQuery("id:z001");
        solrService.commit();
    }
    
    /**
     * 查询数据1
     * @throws SolrServerException 
     */
    @Test
    public void test3() throws SolrServerException {
        //创建连接
        SolrServer solrService = new HttpSolrServer("http://129.204.6.53:8080/solr");
        //创建查询条件对象
        SolrQuery solrQuery = new SolrQuery();
        solrQuery.setQuery("*:*");
        //查询并获取查询的相应对象
        QueryResponse response = solrService.query(solrQuery);
        //从响应对象中获取查询的数据信息
        SolrDocumentList result = response.getResults();
        //查询的条数
        System.out.println("查询的条数:"+result.getNumFound());
        //便利数据集
        for (SolrDocument doc : result) {
            System.out.println("id:"+ doc.get("id"));
            System.out.println("商品名称:"+ doc.get("product_name"));
            System.out.println("商品价格:"+ doc.get("product_price"));
            System.out.println("商品分类名称:"+ doc.get("product_catalog_name"));
            System.out.println("=============分隔符=============");
        }
    }
    
    /**
     * 查询数据  2
     */
    @Test
    public void test4() throws Exception {
        //创建连接
        SolrServer solrService = new HttpSolrServer("http://localhost:8080/solr");
        //创建查询条件
        SolrQuery query = new SolrQuery();
        //设置查询条件
        query.setQuery("台灯");
        //设置默认搜索域
        query.set("df", "product_keywords");
        //根据价格设置过滤条件
        query.addFilterQuery("product_price:[1 TO 100]");
        //设置排序
        query.setSort("product_price",ORDER.desc);
        // 设置分页数据
        // 开始条数
        query.setStart(0);
        //设置一页显示的条数
        query.setRows(10);
        //设置高亮信息
        //高亮默认是关闭的  需要打开
        query.setHighlight(true);
        //设置需要高亮显示的域
        query.addHighlightField("product_name");
        //设置高亮的前缀
        query.setHighlightSimplePre("<span style=\"color:red\">");
        query.setHighlightSimplePost("</span>");
        
        //查询之后获取响应的对象
        QueryResponse response = solrService.query(query);
        //根据响应的对象获取结果集
        SolrDocumentList lists = response.getResults();
        //打印查询数据信息
        System.out.println("查询的条数:"+lists.getNumFound());
        for (SolrDocument doc : lists) {
            System.out.println("id:"+ doc.get("id"));
            //获取高亮的信息
            Map<String, Map<String, List<String>>> highlighting = response.getHighlighting();
            List<String> list = highlighting.get(doc.get("id")).get("product_name");
            if(list != null && list.size() > 0) {
                String hlName = list.get(0);
                System.out.println("高亮的商品名称:"+ hlName);
            }
            
            System.out.println("商品名称:"+ doc.get("product_name"));
            System.out.println("商品价格:"+ doc.get("product_price"));
            System.out.println("商品分类名称:"+ doc.get("product_catalog_name"));
            System.out.println("=============分隔符=============");
        }
        
    }

2、集群版solrj的使用:

public class SolrCloudTest {

    @Test
    public void test1() throws SolrServerException, IOException {
        //创建solr对象   后面ip地址是zookeeper集群的地址
        CloudSolrServer solr = new CloudSolrServer("129.204.6.53:2181,129.204.6.53:2182,129.204.6.53:2183");
        // 设备默认的collection
        solr.setDefaultCollection("collection2");
        //创建一个文档对象
        SolrInputDocument document = new SolrInputDocument();
        document.setField("id", 1);
        document.setField("content", "我是中国人");
        solr.add(document);
        solr.commit();
        
    }
    
    @Test
    public void test2() throws SolrServerException, IOException {
        //创建solr对象   后面ip地址是zookeeper集群的地址
        CloudSolrServer solr = new CloudSolrServer("129.204.6.53:2181,129.204.6.53:2182,129.204.6.53:2183");
        // 设备默认的collection
        solr.setDefaultCollection("collection2");
        SolrQuery solrQuery = new SolrQuery();
        solrQuery.setQuery("*:*");
        //创建一个文档对象
        //查询并获取查询的相应对象
        QueryResponse response = solr.query(solrQuery);
        //从响应对象中获取查询的数据信息
        SolrDocumentList result = response.getResults();
        //查询的条数
        System.out.println("查询的条数: "+ result.getNumFound());
        //便利数据集
        for (SolrDocument doc : result) {
            System.out.println("id:"+ doc.get("id"));
            System.out.println("商品名称:"+ doc.get("content"));
        }
        
    }

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值