當前位置: 首頁>>代碼示例>>Java>>正文


Java SolrInputDocument.setField方法代碼示例

本文整理匯總了Java中org.apache.solr.common.SolrInputDocument.setField方法的典型用法代碼示例。如果您正苦於以下問題:Java SolrInputDocument.setField方法的具體用法?Java SolrInputDocument.setField怎麽用?Java SolrInputDocument.setField使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.solr.common.SolrInputDocument的用法示例。


在下文中一共展示了SolrInputDocument.setField方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testRuntimeLib

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
@Test
public void testRuntimeLib() throws SolrServerException, IOException {
    SearchServer server = testSearchServer.getSearchServer();

    SolrClient client = (SolrClient) server.getBackend();

    SolrInputDocument document = new SolrInputDocument();
    document.setField("_id_", "1");
    document.setField("_type_", "doc");
    document.setField("dynamic_multi_facet_string_f1", "test");
    document.setField("dynamic_multi_facet_string_f2", "hello");

    client.add(document);
    client.commit();

    SolrQuery query = new SolrQuery("t");
    query.setRequestHandler("/suggester");
    query.set("suggestion.df", "facets");
    query.set("suggestion.field", "dynamic_multi_facet_string_f1");

    QueryResponse response = client.query(query);

    assertEquals(1, ((HashMap) response.getResponse().get("suggestions")).get("suggestion_count"));
}
 
開發者ID:RBMHTechnology,項目名稱:vind,代碼行數:25,代碼來源:TestServerTest.java

示例2: addContextFields

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
private void addContextFields(final SolrInputDocument solrDoc, Conversation conversation) {
    if (conversation.getContext() != null) {
        Context ctx = conversation.getContext();
        solrDoc.setField(FIELD_CONTEXT, ctx.getContextType());
        solrDoc.setField(FIELD_ENVIRONMENT, ctx.getEnvironmentType());
        solrDoc.setField(FIELD_DOMAIN, ctx.getDomain());
        if(ctx.getEnvironment() != null){
            ctx.getEnvironment().entrySet().stream()
            .filter(e -> Objects.nonNull(e.getValue()))
            .filter(e -> StringUtils.isNotBlank(e.getKey()) && !e.getValue().isEmpty())
            .filter(e -> !NOT_INDEXED_ENVIRONMENT_FIELDS.contains(e.getKey()))
            .forEach(e -> {
                solrDoc.setField(getEnvironmentField(e.getKey()), e.getValue());
            });
        }
    }
    if(conversation.getMeta() != null){
        conversation.getMeta().getProperties().entrySet().stream()
                .filter(e -> Objects.nonNull(e.getValue()))
                .filter(e -> StringUtils.isNotBlank(e.getKey()) && !e.getValue().isEmpty())
                .filter(e -> !NOT_INDEXED_META_FIELDS.contains(e.getKey()))
                .forEach(e -> {
                    solrDoc.setField(getMetaField(e.getKey()), e.getValue());
                });
    }
}
 
開發者ID:redlink-gmbh,項目名稱:smarti,代碼行數:27,代碼來源:ConversationIndexer.java

示例3: createDocuments

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
/**
 * Generates a list of test documents for insertion.
 *
 * @return the list of json String representing the documents
 */
static List<SolrInputDocument> createDocuments(long numDocs) {
  String[] scientists = {
    "Lovelace",
    "Franklin",
    "Meitner",
    "Hopper",
    "Curie",
    "Faraday",
    "Newton",
    "Bohr",
    "Galilei",
    "Maxwell"
  };
  ArrayList<SolrInputDocument> data = new ArrayList<>();
  for (int i = 0; i < numDocs; i++) {
    int index = i % scientists.length;
    SolrInputDocument doc = new SolrInputDocument();
    doc.setField("id", String.valueOf(i));
    doc.setField("scientist", scientists[index]);
    data.add(doc);
  }
  return data;
}
 
開發者ID:apache,項目名稱:beam,代碼行數:29,代碼來源:SolrIOTestUtils.java

示例4: checkAndCreateGroupDoc

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
/**
 * 
 * @param groupIdField Field name of the group identifier.
 * @param groupId Field value of the group identifier.
 * @param metadata Map with additional metadat fields to add to the group document.
 * @param iddoc IDDOC for the new document.
 * @return Group SolrInputDocument, if created.
 * @should create new document with all values if none exists
 * @should create updated document with all values if one already exists
 */
public SolrInputDocument checkAndCreateGroupDoc(String groupIdField, String groupId, Map<String, String> metadata, long iddoc) {
    try {
        SolrDocumentList docs = search(SolrConstants.PI + ":" + groupId, null);
        SolrInputDocument doc = new SolrInputDocument();
        Date now = new Date();
        if (docs.isEmpty()) {
            // Document does not exist yet
            doc.setField(SolrConstants.IDDOC, String.valueOf(iddoc));
            doc.setField(SolrConstants.GROUPFIELD, String.valueOf(iddoc));
            doc.setField(SolrConstants.DOCTYPE, DocType.GROUP.name());
            doc.setField(SolrConstants.DATECREATED, now.getTime());
        } else {
            // A document already exists for this groupId
            SolrDocument oldDoc = docs.get(0);
            doc.setField(SolrConstants.IDDOC, oldDoc.getFieldValue(SolrConstants.IDDOC));
            if (doc.getField(SolrConstants.GROUPFIELD) == null) {
                doc.setField(SolrConstants.GROUPFIELD, oldDoc.getFieldValue(SolrConstants.IDDOC));
            }
            doc.setField(SolrConstants.DOCTYPE, DocType.GROUP.name());
            doc.setField(SolrConstants.DATECREATED, oldDoc.getFieldValue(SolrConstants.DATECREATED));
        }
        doc.setField(SolrConstants.DATEUPDATED, now.getTime());
        doc.setField(SolrConstants.PI, groupId);
        doc.setField(SolrConstants.PI_TOPSTRUCT, groupId);
        doc.setField(SolrConstants.GROUPTYPE, groupIdField);
        if (metadata != null) {
            for (String fieldName : metadata.keySet()) {
                String fieldValue = metadata.get(fieldName);
                doc.setField(fieldName, fieldValue);
            }
        }
        return doc;
    } catch (SolrServerException e) {
        logger.error(e.getMessage(), e);
    }

    return null;
}
 
開發者ID:intranda,項目名稱:goobi-viewer-indexer,代碼行數:49,代碼來源:SolrHelper.java

示例5: updateConversation

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
@Override
public void updateConversation(Conversation conversation, Date syncDate) {
    try (SolrClient solr = solrServer.getSolrClient(conversationCore)){
        SolrInputDocument doc = toSolrInputDocument(conversation);
        if(doc != null){
            doc.setField(FIELD_SYNC_DATE, syncDate);
            solr.add(doc, commitWithin);
        } else { //remove from index
            solr.deleteByQuery(getDeleteQuery(conversation),commitWithin);
        }
    } catch (IOException | SolrServerException e) {
        log.warn("Unable to index Conversation {} ({}: {})",conversation.getId(), e.getClass().getSimpleName(), e.getMessage());
        log.debug("STACKTRACE",e);
    }        
}
 
開發者ID:redlink-gmbh,項目名稱:smarti,代碼行數:16,代碼來源:ConversationIndexer.java

示例6: toSolrInputDocument

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
private SolrInputDocument toSolrInputDocument(Message message, int i, Conversation conversation) {
    final SolrInputDocument solrMsg = new SolrInputDocument();
    String id = new StringBuilder(conversation.getId().toHexString()).append('_')
            //we prefer to use the messageId but some system might not provide a such so we have a fallback
            //to the index within the conversation
            .append(StringUtils.isNoneBlank(message.getId()) ? message.getId() : String.valueOf(i)).toString();
    solrMsg.setField(FIELD_ID, id);
    solrMsg.setField(FIELD_CONVERSATION_ID, conversation.getId());
    solrMsg.setField(FIELD_MESSAGE_ID, message.getId());
    solrMsg.setField(FIELD_MESSAGE_IDX, i);
    //#150 index the current version of the index so that we can detect the need of a
    //full re-index after a software update on startup
    solrMsg.setField(FIELD_INDEX_VERSION, CONVERSATION_INDEX_VERSION);
    solrMsg.setField(FIELD_TYPE, TYPE_MESSAGE);
    if (message.getUser() != null) {
        solrMsg.setField(FIELD_USER_ID, message.getUser().getId());
        solrMsg.setField(FIELD_USER_NAME, message.getUser().getDisplayName());
    }

    //add owner and context information
    solrMsg.setField(FIELD_OWNER, conversation.getOwner().toHexString());
    addContextFields(solrMsg, conversation);

    solrMsg.setField(FIELD_MESSAGE, message.getContent());
    solrMsg.setField(FIELD_TIME, message.getTime());
    solrMsg.setField(FIELD_VOTE, message.getVotes());

    // TODO: Add keywords, links, ...

    return solrMsg;
}
 
開發者ID:redlink-gmbh,項目名稱:smarti,代碼行數:32,代碼來源:ConversationIndexer.java

示例7: accumulate

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
@Override
public void accumulate(SolrInputDocument document, Path filePath, BasicFileAttributes attributes)
    throws IOException {
    MCRPath mcrPath = MCRPath.toMCRPath(filePath); //check if this is an MCRPath -> more metadata
    String ownerID = mcrPath.getOwner();
    String absolutePath = '/' + filePath.subpath(0, filePath.getNameCount()).toString();

    String urn = MCRURNManager.getURNForFile(ownerID,
        absolutePath.substring(0, absolutePath.lastIndexOf("/") + 1), filePath.getFileName().toString());
    if (urn != null) {
        document.setField("fileURN", urn);
    }
}
 
開發者ID:MyCoRe-Org,項目名稱:mycore,代碼行數:14,代碼來源:MCRSolrFileIndexURNAccumulator.java

示例8: toSolrDocument

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
public SolrInputDocument toSolrDocument() {
    SolrInputDocument doc = new SolrInputDocument();
    LinkedList<MCRCategory> ancestors = MCRSolrClassificationUtil.getAncestors(category);
    MCRCategory parent = !ancestors.isEmpty() ? ancestors.getLast() : null;
    // ids
    MCRCategoryID id = category.getId();
    doc.setField("id", id.toString());
    doc.setField("classification", id.getRootID());
    doc.setField("type", "node");
    if (category.isCategory()) {
        doc.setField("category", id.getID());
    }
    // labels
    Set<MCRLabel> labels = category.getLabels();
    for (MCRLabel label : labels) {
        doc.addField("label." + label.getLang(), label.getText());
    }
    // children
    if (category.hasChildren()) {
        for (MCRCategory child : category.getChildren()) {
            doc.addField("children", child.getId().toString());
        }
    }
    // parent
    if (parent != null) {
        doc.setField("parent", parent.getId().toString());
        doc.setField("index", parent.getChildren().indexOf(category));
    }
    // ancestors
    for (MCRCategory ancestor : ancestors) {
        doc.addField("ancestors", ancestor.getId().toString());
    }
    return doc;
}
 
開發者ID:MyCoRe-Org,項目名稱:mycore,代碼行數:35,代碼來源:MCRSolrCategory.java

示例9: setUp

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
/**
 * Indexes some sample data as test fixture.
 * 
 * @throws Exception hopefully never, otherwise the test will fail.
 */
@Before
public void setUp() throws Exception {
	super.setUp();
	final SolrClient indexer = getSolrClient();
	final SolrInputDocument book1 = new SolrInputDocument();
	book1.setField("id","1");
	book1.setField("title","Apache Solr Essentials");
	book1.setField("author","Andrea Gazzarini");
	
	indexer.add(book1);
	indexer.commit();
}
 
開發者ID:spaziocodice,項目名稱:invisible-queries-request-handler,代碼行數:18,代碼來源:FacadeRequestHandler_IT.java

示例10: SolrCloudFixture

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
public SolrCloudFixture(String solrHome) throws Exception {
    String xml = IOHelper.loadText(new FileInputStream(new File(solrHome, "solr-no-core.xml")));
    miniCluster = new MiniSolrCloudCluster(1, "/solr", new File("target/tmp").toPath(), xml, null, null);
    String zkAddr = miniCluster.getZkServer().getZkAddress();
    String zkHost = miniCluster.getZkServer().getZkHost();

    buildZooKeeper(zkHost, zkAddr, new File(solrHome), "solrconfig.xml", "schema.xml");
    List<JettySolrRunner> jettys = miniCluster.getJettySolrRunners();
    for (JettySolrRunner jetty : jettys) {
        if (!jetty.isRunning()) {
            log.warn("JETTY NOT RUNNING!");
        } else {
            log.info("JETTY RUNNING AT " + jetty.getBaseUrl() + " PORT " + jetty.getLocalPort());
        }
    }

    solrClient = new CloudSolrClient(zkAddr, true);
    solrClient.connect();

    createCollection(solrClient, "collection1", 1, 1, "conf1");
    Thread.sleep(1000); // takes some time to setup the collection...
                        // otherwise you'll get no live solr servers
    solrClient.setDefaultCollection("collection1");

    SolrInputDocument doc = new SolrInputDocument();
    doc.setField("id", "1");

    solrClient.add(doc);
    solrClient.commit();
}
 
開發者ID:HydAu,項目名稱:Camel,代碼行數:31,代碼來源:SolrCloudFixture.java

示例11: toSolrInputDoc

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
private SolrInputDocument toSolrInputDoc()
{
   SolrInputDocument doc = new SolrInputDocument();
   doc.setField("path", DEFAULT_PATH);
   doc.setField("id", id);
   doc.setField("uuid", uuid);

   // Metadata
   if (indexes != null && !indexes.isEmpty())
   {
      for (MetadataIndex index: indexes)
      {
         String type = index.getType();

         // Only textual information stored in field contents (full-text search)
         if ((type == null) || type.isEmpty() || "text/plain".equals(type))
         {
            doc.addField("contents", index.getValue());
         }

         MetadataType mt =
               ApplicationContextProvider.getBean(MetadataTypeService.class)
                     .getMetadataTypeByName(itemClass.getOntClass().getURI(), index.getName());

         SolrField sf = (mt != null) ? mt.getSolrField() : null;

         if (sf != null || index.getQueryable() != null)
         {
            Boolean is_multivalued = (sf != null) ? sf.isMultiValued() : null;

            String field_name = (sf != null) ? sf.getName() : index.getQueryable().toLowerCase();

            if (is_multivalued != null && is_multivalued)
            {
               doc.addField(field_name, index.getValue());
            }
            else
            {
               doc.setField(field_name, index.getValue());
            }
            LOGGER.debug("Added {}: {}", field_name, index.getValue());
         }
      }
   }
   else
   {
      LOGGER.warn("Product '{}' contains no metadata", identifier);
   }

   return doc;
}
 
開發者ID:SentinelDataHub,項目名稱:dhus-core,代碼行數:52,代碼來源:DatabaseProduct.java

示例12: toInputDocument

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
/**
 * Makes a SolrInputDocument from a Product database object.
 * The returned document can be indexed as is.
 * @param product to convert.
 * @return an indexable solr document.
 */
private SolrInputDocument toInputDocument(Product product)
{
   SolrInputDocument doc = new SolrInputDocument();

   // Metadatas
   List<MetadataIndex> indices = product.getIndexes();
   if (indices != null && !indices.isEmpty())
   {
      for (MetadataIndex index : indices)
      {
         String type = index.getType();

         // Only textual information stored in field contents (full-text search)
         if ((type == null) || type.isEmpty() || "text/plain".equals(type))
         {
            doc.addField("contents", index.getValue());
         }

         // next line is considered bad practice:
         //doc.addField("contents", index.getQueryable());

         MetadataType mt = metadataTypeService
               .getMetadataTypeByName(product.getItemClass(), index.getName());
         SolrField sf = (mt != null)? mt.getSolrField(): null;

         if (sf != null || index.getQueryable() != null)
         {
            Boolean is_multivalued = (sf != null)? sf.isMultiValued(): null;
            String field_name = (sf != null)? sf.getName(): index.getQueryable().toLowerCase();

            if (is_multivalued != null && is_multivalued)
            {
               doc.addField(field_name, index.getValue());
            }
            else
            {
               doc.setField(field_name, index.getValue());
            }

            //LOGGER.debug("Added " + field_name + ":" + index.getValue());
         }
      }
   }
   else
   {
      LOGGER.warn("Product '" + product.getIdentifier() + "' contains no metadata");
   }

   // DHuS Attributes
   doc.setField("id", product.getId());
   doc.setField("uuid", product.getUuid());
   doc.setField("path", DEFAULT_PATH);

   // Collections
   List<Collection> collections = collectionService.getCollectionsOfProduct(product);
   if (collections != null && !collections.isEmpty())
   {
      for (Collection collection : collections)
      {
         doc.addField("collection", collection.getName());
      }
   }

   return doc;
}
 
開發者ID:SentinelDataHub,項目名稱:dhus-core,代碼行數:72,代碼來源:SearchService.java

示例13: deskewAlto_handleMissingFilename

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
@Test
public void deskewAlto_handleMissingFilename() throws Exception {

    //        String filename = "AC04987957_00000124";
    String[] filenames = { "00000005.tif", "00225231.png" };

    int[] imageWidth = { 4966, 2794 };

    MetsIndexer indexer = new MetsIndexer(hotfolder);
    File dataFolder = new File("resources/test/alto_deskew");

    int i = 0;
    for (String filename : filenames) {

        String baseFilename = FilenameUtils.getBaseName(filename);

        File altoFile = new File(dataFolder, baseFilename + ".xml");
        String origAltoString = FileUtils.readFileToString(altoFile);
        File outputFolder = new File(dataFolder, "output");
        if (outputFolder.isDirectory()) {
            FileUtils.deleteDirectory(outputFolder);
        }
        outputFolder.mkdir();

        Map<String, Path> dataFolders = new HashMap<>();
        dataFolders.put(DataRepository.PARAM_MEDIA, Paths.get(dataFolder.getAbsolutePath()));

        SolrInputDocument doc = new SolrInputDocument();
        doc.setField(SolrConstants.ALTO, origAltoString);
        doc.setField(SolrConstants.WIDTH, "" + imageWidth[i]);
        //            doc.setField(SolrConstants.FILENAME, filename);

        MetsIndexer.deskewAlto(dataFolders, doc);
        String deskewedAltoString = (String) doc.getFieldValue(SolrConstants.ALTO);
        AltoDocument deskewedDoc = AltoDocument.getDocumentFromString(deskewedAltoString);
        FileUtils.writeStringToFile(new File(outputFolder, filename + ".xml"), deskewedAltoString, false);
        Word testWord = (Word) deskewedDoc.getFirstPage().getAllWordsAsList().get(1);
        Assert.assertNotNull(testWord);
        if (filename.equals("00000005.tif")) {
            Assert.assertEquals("Name", testWord.getContent());
            //                Assert.assertEquals(new Rectangle2D.Float(327, 765, 228, 54), testWord.getRect());
            Assert.assertEquals("Tag0", testWord.getAttributeValue("TAGREFS"));
            Assert.assertEquals("Tag0", deskewedDoc.getTags().getTags().getChild("NamedEntityTag", null).getAttributeValue("ID"));
        }

        i++;
    }
}
 
開發者ID:intranda,項目名稱:goobi-viewer-indexer,代碼行數:49,代碼來源:MetsIndexerTest.java

示例14: mergeSolrUInputDoc

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
private SolrInputDocument mergeSolrUInputDoc(SolrInputDocument prev, SolrInputDocument current) {
    prev.setField(FIELD_MESSAGE, String.format("%s%n%s", prev.getFieldValue(FIELD_MESSAGE), current.getFieldValue(FIELD_MESSAGE)));
    prev.setField(FIELD_VOTE, Integer.parseInt(String.valueOf(prev.getFieldValue(FIELD_VOTE))) + Integer.parseInt(String.valueOf(current.getFieldValue(FIELD_VOTE))));
    return prev;
}
 
開發者ID:redlink-gmbh,項目名稱:smarti,代碼行數:6,代碼來源:ConversationIndexer.java

示例15: setFloat32Field

import org.apache.solr.common.SolrInputDocument; //導入方法依賴的package包/類
@Override
protected void setFloat32Field(SolrInputDocument result, String fieldName, Float value) {
  result.setField(fieldName, value);
}
 
開發者ID:jcustenborder,項目名稱:kafka-connect-solr,代碼行數:5,代碼來源:SolrInputDocumentConverter.java


注:本文中的org.apache.solr.common.SolrInputDocument.setField方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。