溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SolrJ 中怎么操作solr增刪改查

發(fā)布時(shí)間:2021-07-27 15:49:02 來(lái)源:億速云 閱讀:149 作者:Leah 欄目:大數(shù)據(jù)

今天就跟大家聊聊有關(guān)SolrJ 中怎么操作solr增刪改查,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

Solr的特性包括:
? 高級(jí)的全文搜索功能 
? 專為高通量的網(wǎng)絡(luò)流量進(jìn)行的優(yōu)化 
? 基于開放接口(XML和HTTP)的標(biāo)準(zhǔn) 
? 綜合的HTML管理界面 
? 可伸縮性-能夠有效地復(fù)制到另外一個(gè)Solr搜索服務(wù)器 
? 使用XML配置達(dá)到靈活性和適配性 
? 可擴(kuò)展的插件體系

 //分頁(yè)查詢
 //創(chuàng)建SolrServer對(duì)象,要對(duì)solr
 HttpSolrServer server = new HttpSolrServer(url);
        //連接solr服務(wù)器超時(shí)時(shí)間 單位毫秒
         server.setConnectionTimeout(timeout);
        //是否允許跟蹤重定向 默認(rèn)false
         server.setFollowRedirects(followRedirects);
      //是否允許壓縮
         server.setAllowCompression(allowCompression);
     //最大重新連接次數(shù)
         server.setMaxRetries(maxRetries);
//創(chuàng)建查詢對(duì)象
 SolrQuery query = communitySolrHandler.createQuery(pagination);

public SolrQuery createQuery(Pagination<CommunitySolrField> pagination){
       SolrQuery query = new SolrQuery();
       CommunitySolrField k  = pagination.getDto();
       String value = k.getShortPy();
       StringBuilder sb = new StringBuilder();
       //拼接查詢條件
       if (!CollectionUtils.isEmpty(k.getRegionIds())){
           for (String regionId:k.getRegionIds()){
               sb.append(" regionId:"+regionId);
           }

       }
       if (!CollectionUtils.isEmpty(k.getProjectIds())){
           for (String projectId:k.getProjectIds()){
               sb.append(" projectId:"+projectId);
           }

       }
       query.setQuery(sb.toString());
       //在滿足上面條件之外 過(guò)濾下面的條件
       if (StringUtils.hasText(value)){
           if (ToolUtils.matcherZh(value)){
               query.addFilterQuery(" communityName:"+value);
           }else {
               query.addFilterQuery("shortPiny:"+value.toLowerCase()+"*" );
           }

       }
       //分頁(yè)返回結(jié)果
       int  start =  ToolUtils.start(pagination.getPageNo(), pagination.getPageSize()) ;
     // 從第幾條開始查詢
       query.setStart(start);
       query.setRows(pagination.getPageSize());
       return  query;
   }

//更新索引 一般這段代碼是用定時(shí)任務(wù)來(lái)跑得
 ConcurrentUpdateSolrServer server = new ConcurrentUpdateSolrServer(solrJSearchClient.getUrl()+ SolrTable.community.toString(), solrJSearchClient.getQueueSize(), solrJSearchClient.getThreadCount());
        List<CommunityDto> list =  communityDao.findAllCommunitySolr() ;
        if (CollectionUtils.isEmpty(list)) {
            return;
        }
        List<String> ids = new ArrayList<String>();
        List<SolrInputDocument> docs = new ArrayList<SolrInputDocument>();
        SolrInputDocument doc;
        HanZi hanZi;
        for (CommunityDto communityDto:list){
            doc = new SolrInputDocument();
            hanZi = new HanZi(communityDto.getName());
            doc.addField("id",communityDto.getId());
            doc.addField("communityName",communityDto.getName());
            doc.addField("piny",communityDto.getPiny());
            doc.addField("shortPiny",hanZi.getPinYinHeadChar());
            doc.addField("sortDefault",communityDto.getSortDefault());
            doc.addField("regionId",communityDto.getDicRegionId());
            doc.addField("projectId",communityDto.getProjectId());
            docs.add(doc);
            ids.add(communityDto.getId());
        }
        try {
            //先刪除
            server.deleteById(ids);
            server.commit();
            //再添加/更新索引
            server.add(docs);
            //對(duì)索引進(jìn)行優(yōu)化
            server.optimize();
            server.commit();
        } catch (Exception e) {
            e.printStackTrace();
        }

看完上述內(nèi)容,你們對(duì)SolrJ 中怎么操作solr增刪改查有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI