Package org.apache.solr.update.processor
Class AtomicUpdateDocumentMerger
java.lang.Object
org.apache.solr.update.processor.AtomicUpdateDocumentMerger
- WARNING: This API is experimental and might change in incompatible ways in the next release.
-
Field Summary
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionGiven an add update command, compute a list of fields that can be updated in-place.protected voiddoAdd(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) protected voiddoAddDistinct(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) protected voiddoInc(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) booleandoInPlaceUpdateMerge(AddUpdateCommand cmd, Set<String> updatedFields) Given an AddUpdateCommand containing update operations (e.g.protected voiddoRemove(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) protected voiddoRemoveRegex(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object valuePatterns) protected voiddoSet(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) static booleanUtility method that examines the SolrInputDocument in an AddUpdateCommand and returns true if the documents contains atomic update instructions.static booleanisDerivedFromDoc(org.apache.solr.common.SolrInputDocument fullDoc, org.apache.solr.common.SolrInputDocument partialDoc) static booleanisSupportedFieldForInPlaceUpdate(SchemaField schemaField) Given a schema field, return whether or not such a field is supported for an in-place update.org.apache.solr.common.SolrInputDocumentmerge(org.apache.solr.common.SolrInputDocument sdoc, org.apache.solr.common.SolrInputDocument toDoc) Merges the fromDoc into the toDoc using the atomic update syntax.
-
Field Details
-
schema
-
idField
-
-
Constructor Details
-
AtomicUpdateDocumentMerger
-
-
Method Details
-
isAtomicUpdate
Utility method that examines the SolrInputDocument in an AddUpdateCommand and returns true if the documents contains atomic update instructions. -
merge
public org.apache.solr.common.SolrInputDocument merge(org.apache.solr.common.SolrInputDocument sdoc, org.apache.solr.common.SolrInputDocument toDoc) Merges the fromDoc into the toDoc using the atomic update syntax. This method will look for a nested document (possiblytoDocitself) with an equal ID, and merge into that one.- Parameters:
sdoc- the doc containing update instructionstoDoc- the target doc (possibly nested) before the update (will be modified in-place)- Returns:
- toDoc with modifications; never null
-
isSupportedFieldForInPlaceUpdate
Given a schema field, return whether or not such a field is supported for an in-place update. Note: If an update command has updates to only supported fields (and _version_ is also supported), only then is such an update command executed as an in-place update. -
computeInPlaceUpdatableFields
Given an add update command, compute a list of fields that can be updated in-place. If there is even a single field in the update that cannot be updated in-place, the entire update cannot be executed in-place (and empty set will be returned in that case).- Returns:
- Return a set of fields that can be in-place updated.
- Throws:
IOException
-
isDerivedFromDoc
public static boolean isDerivedFromDoc(org.apache.solr.common.SolrInputDocument fullDoc, org.apache.solr.common.SolrInputDocument partialDoc) - Parameters:
fullDoc- the full doc to be compared againstpartialDoc- the sub document to be tested- Returns:
- whether partialDoc is derived from fullDoc
-
doInPlaceUpdateMerge
public boolean doInPlaceUpdateMerge(AddUpdateCommand cmd, Set<String> updatedFields) throws IOException Given an AddUpdateCommand containing update operations (e.g. set, inc), merge and resolve the operations into a partial document that can be used for indexing the in-place updates. The AddUpdateCommand is modified to contain the partial document (instead of the original document which contained the update operations) and also the prevVersion that this in-place update depends on. Note: updatedFields passed into the method can be changed, i.e. the version field can be added to the set.- Returns:
- If in-place update cannot succeed, e.g. if the old document is deleted recently, then false is returned. A false return indicates that this update can be re-tried as a full atomic update. Returns true if the in-place update succeeds.
- Throws:
IOException
-
doSet
protected void doSet(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) -
doAdd
protected void doAdd(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) -
doAddDistinct
protected void doAddDistinct(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) -
doInc
protected void doInc(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) -
doRemove
protected void doRemove(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object fieldVal) -
doRemoveRegex
protected void doRemoveRegex(org.apache.solr.common.SolrInputDocument toDoc, org.apache.solr.common.SolrInputField sif, Object valuePatterns)
-