本文整理匯總了Java中org.apache.solr.common.SolrDocumentList.get方法的典型用法代碼示例。如果您正苦於以下問題:Java SolrDocumentList.get方法的具體用法?Java SolrDocumentList.get怎麽用?Java SolrDocumentList.get使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.apache.solr.common.SolrDocumentList
的用法示例。
在下文中一共展示了SolrDocumentList.get方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: createListIdentifiers
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
/**
* for the server request ?verb=ListIdentifiers this method build the xml section
*
* @param handler
* @param firstRow
* @param numRows
* @return
* @throws SolrServerException
*/
public Element createListIdentifiers(RequestHandler handler, int firstRow, int numRows) throws SolrServerException {
Map<String, String> datestamp = filterDatestampFromRequest(handler);
SolrDocumentList listIdentifiers = solr.getListIdentifiers(datestamp, firstRow, numRows, false);
if (listIdentifiers == null || listIdentifiers.isEmpty()) {
return new ErrorCode().getNoRecordsMatch();
}
Namespace xmlns = DataManager.getInstance().getConfiguration().getStandardNameSpace();
Element xmlListIdentifiers = new Element("ListIdentifiers", xmlns);
long totalHits = listIdentifiers.getNumFound();
for (int i = 0; i < listIdentifiers.size(); i++) {
SolrDocument doc = listIdentifiers.get(i);
Element header = getHeader(doc, null, handler);
xmlListIdentifiers.addContent(header);
}
// Create resumption token
if (totalHits > firstRow + numRows) {
Element resumption = createResumptionTokenAndElement(totalHits, firstRow + numRows, xmlns, handler);
xmlListIdentifiers.addContent(resumption);
}
return xmlListIdentifiers;
}
示例2: prepareUpdate
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
/**
* Prepares the given record for an update. Creation timestamp is preserved. A new update timestamp is added, child docs are removed.
*
* @param indexObj {@link IndexObject}
* @throws IOException -
* @throws SolrServerException
* @throws FatalIndexerException
*/
private void prepareUpdate(IndexObject indexObj) throws IOException, SolrServerException, FatalIndexerException {
String pi = indexObj.getPi().trim();
SolrDocumentList hits = hotfolder.getSolrHelper().search(SolrConstants.PI + ":" + pi, null);
if (hits != null && hits.getNumFound() > 0) {
logger.debug("This file has already been indexed, initiating an UPDATE instead...");
indexObj.setUpdate(true);
SolrDocument doc = hits.get(0);
// Set creation timestamp, if exists (should never be updated)
Object dateCreated = doc.getFieldValue(SolrConstants.DATECREATED);
if (dateCreated != null) {
// Set creation timestamp, if exists (should never be updated)
indexObj.setDateCreated((Long) dateCreated);
}
// Set update timestamp
Collection<Object> dateUpdatedValues = doc.getFieldValues(SolrConstants.DATEUPDATED);
if (dateUpdatedValues != null) {
for (Object date : dateUpdatedValues) {
indexObj.getDateUpdated().add((Long) date);
}
}
// Recursively delete all children
deleteWithPI(pi, false, hotfolder.getSolrHelper());
}
}
示例3: getSolrDocument
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
public SolrDocument getSolrDocument(String docId) {
if (docId == null) {
throw new NullPointerException("Cannot get SOLR document for null docId");
}
SolrDocument result = null;
SolrQuery query = new SolrQuery();
query.setQuery("id:" + ClientUtils.escapeQueryChars(docId));
query.setFields("*");
SolrDocumentList docs = fireQuery(query).getResults();
if (docs.getNumFound() > 1) {
logger.error("Error: found multiple documents for id (will return first one): " + docId + " \nDocuments found: " + docs);
result = docs.get(0);
} else if (docs.getNumFound() == 1) {
result = docs.get(0);
}
return result;
}
示例4: assertQ
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
protected void assertQ(String query, int expectedCount, String... expectedFields)
throws SolrServerException, IOException {
SolrQuery solrQuery = new SolrQuery();
solrQuery.setQuery(query);
QueryResponse rsp = cloudSolrClient.query(solrQuery);
SolrDocumentList docs = rsp.getResults();
assertEquals(expectedCount, docs.size());
log.info("docs: " + docs.toString());
if (docs.isEmpty()) {
fail("No results for query " + query);
}
SolrDocument doc = docs.get(0);
if (expectedFields != null) {
for (int counter = 0; counter < expectedFields.length; counter += 2) {
assertTrue(
doc.getFieldValue(expectedFields[counter]).toString() + " != " + expectedFields[counter
+ 1], doc.getFieldValue(expectedFields[counter]).toString()
.equals(expectedFields[counter + 1]));
}
}
}
示例5: assertFieldValues
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
/**
* Fails if the number of documents in the given SolrDocumentList differs
* from the given number of expected values, or if any of the values in the
* given field don't match the expected values in the same order.
*/
public static void assertFieldValues(SolrDocumentList documents, String fieldName, Object... expectedValues) {
if (documents.size() != expectedValues.length) {
fail("Number of documents (" + documents.size()
+ ") is different from number of expected values (" + expectedValues.length);
}
for (int docNum = 1 ; docNum <= documents.size() ; ++docNum) {
SolrDocument doc = documents.get(docNum - 1);
Object expected = expectedValues[docNum - 1];
Object actual = doc.get(fieldName);
if ((null == expected && null != actual) ||
(null != expected && null == actual) ||
(null != expected && null != actual && !expected.equals(actual))) {
fail("Unexpected " + fieldName + " field value in document #" + docNum
+ ": expected=[" + expected + "], actual=[" + actual + "]");
}
}
}
示例6: testSimple
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
@Test
public void testSimple() throws Exception {
DirectXmlRequest req = new DirectXmlRequest("/dataimport", xml);
ModifiableSolrParams params = new ModifiableSolrParams();
params.set("command", "full-import");
params.set("clean", "false");
req.setParams(params);
HttpSolrServer solrServer = new HttpSolrServer(buildUrl(jetty.getLocalPort(), "/solr"));
solrServer.request(req);
ModifiableSolrParams qparams = new ModifiableSolrParams();
qparams.add("q", "*:*");
QueryResponse qres = solrServer.query(qparams);
SolrDocumentList results = qres.getResults();
assertEquals(2, results.getNumFound());
SolrDocument doc = results.get(0);
assertEquals("1", doc.getFieldValue("id"));
assertEquals("Hello C1", ((List)doc.getFieldValue("desc")).get(0));
solrServer.shutdown();
}
示例7: assertExpandGroupCountAndOrder
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
private void assertExpandGroupCountAndOrder(String group, int count, Map<String, SolrDocumentList>expandedResults, String... docs) throws Exception {
SolrDocumentList results = expandedResults.get(group);
if(results == null) {
throw new Exception("Group Not Found:"+group);
}
if(results.size() != count) {
throw new Exception("Expected Count "+results.size()+" Not Found:"+count);
}
for(int i=0; i<docs.length;i++) {
String id = docs[i];
SolrDocument doc = results.get(i);
if(!doc.getFieldValue("id").toString().equals(id)) {
throw new Exception("Id not in results or out of order:"+id+"!="+doc.getFieldValue("id"));
}
}
}
示例8: prepareUpdate
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
/**
* Prepares the given record for an update. Creation timestamp and representative thumbnail and anchor IDDOC are preserved. A new update timestamp
* is added, child docs are removed.
*
* @param indexObj {@link IndexObject}
* @throws IOException
* @throws SolrServerException
* @throws FatalIndexerException
* @should keep creation timestamp
* @should set update timestamp correctly
* @should keep representation thumbnail
* @should keep anchor IDDOC
* @should delete anchor secondary docs
*/
protected void prepareUpdate(IndexObject indexObj) throws IOException, SolrServerException, FatalIndexerException {
String pi = indexObj.getPi().trim();
SolrDocumentList hits = hotfolder.getSolrHelper().search(SolrConstants.PI + ":" + pi, null);
if (hits != null && hits.getNumFound() > 0) {
logger.debug("This file has already been indexed, initiating an UPDATE instead...");
indexObj.setUpdate(true);
SolrDocument doc = hits.get(0);
// Set creation timestamp, if exists (should never be updated)
Object dateCreated = doc.getFieldValue(SolrConstants.DATECREATED);
if (dateCreated != null) {
// Set creation timestamp, if exists (should never be updated)
indexObj.setDateCreated((Long) dateCreated);
}
// Set update timestamp
Collection<Object> dateUpdatedValues = doc.getFieldValues(SolrConstants.DATEUPDATED);
if (dateUpdatedValues != null) {
for (Object date : dateUpdatedValues) {
indexObj.getDateUpdated().add((Long) date);
}
}
// Set previous representation thumbnail, if available
Object thumbnail = doc.getFieldValue(SolrConstants.THUMBNAILREPRESENT);
if (thumbnail != null) {
indexObj.setThumbnailRepresent((String) thumbnail);
}
// Recursively delete all children, if not an anchor
deleteWithPI(pi, false, hotfolder.getSolrHelper());
}
}
示例9: checkAndCreateGroupDoc
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的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;
}
示例10: getDocument
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
@Override
public SolrDocument getDocument(String docId) {
final SolrQuery query = queryFatory.createDocumentQuery(docId);
final SolrDocumentList result = searchResultsDao.getDocuments(query);
if (result.size() < 1) {
return null;
} else {
logger.debug("Document with docId {} retrieved:", result);
return result.get(0);
}
}
示例11: indexModel_sampleModel_shouldIndexAllModelSplits
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
@Test
public void indexModel_sampleModel_shouldIndexAllModelSplits() throws IOException, SolrServerException {
String sampleModelsDirPath = getResourcePath();
String modelJson = "lambdaMARTModel1.json";
modelIndexerToTest.indexModel(sampleModelsDirPath + "/" + modelJson);
final QueryResponse allDocs = embeddedSolrServer.query(new SolrQuery("*:*"));
final SolrDocumentList results = allDocs.getResults();
assertThat(results.getNumFound(),is(4L));
final SolrDocument split1 = results.get(0);
assertThat(split1.getFieldValue(SolrFields.Models.MODEL_NAME),is("lambdaMARTModel1"));
assertThat(split1.getFieldValue(SolrFields.Models.FEATURE),is("feature1"));
assertThat(split1.getFieldValue(SolrFields.Models.THRESHOLD),is(0.5));
final SolrDocument split2 = results.get(1);
assertThat(split2.getFieldValue(SolrFields.Models.MODEL_NAME),is("lambdaMARTModel1"));
assertThat(split2.getFieldValue(SolrFields.Models.FEATURE),is("feature2"));
assertThat(split2.getFieldValue(SolrFields.Models.THRESHOLD),is(10.0));
final SolrDocument split3 = results.get(2);
assertThat(split3.getFieldValue(SolrFields.Models.MODEL_NAME),is("lambdaMARTModel1"));
assertThat(split3.getFieldValue(SolrFields.Models.FEATURE),is("feature2"));
assertThat(split3.getFieldValue(SolrFields.Models.THRESHOLD),is(0.8));
final SolrDocument split4 = results.get(3);
assertThat(split4.getFieldValue(SolrFields.Models.MODEL_NAME),is("lambdaMARTModel1"));
assertThat(split4.getFieldValue(SolrFields.Models.FEATURE),is("feature1"));
assertThat(split4.getFieldValue(SolrFields.Models.THRESHOLD),is(100.0));
}
示例12: indexTrainingSet_noFeatureMappingSpecified_shouldIndexPlainFeaturesNames
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
@Test
public void indexTrainingSet_noFeatureMappingSpecified_shouldIndexPlainFeaturesNames() throws IOException, SolrServerException {
String sampleModelsDirPath = getResourcePath();
String trainingSet="trainingSet1";
trainingSetIndexerToTest.indexTrainingSet(sampleModelsDirPath+"/"+trainingSet,null,null);
final QueryResponse allDocs = embeddedSolrServer.query(new SolrQuery("*:*"));
final SolrDocumentList results = allDocs.getResults();
assertThat(results.getNumFound(),is(4L));
final SolrDocument sample1 = results.get(0);
assertThat(sample1.getFieldValue(SolrFields.TrainingSet.RELEVANCY),is(1.0));
assertThat(sample1.getFieldValue("1"),is(300.0));
assertThat(sample1.getFieldValue("2"),is(4.0));
assertThat(sample1.getFieldValue("3"),is(1.0));
assertThat(sample1.getFieldValue("6"),is(1.0));
final SolrDocument sample2 = results.get(1);
assertThat(sample2.getFieldValue(SolrFields.TrainingSet.RELEVANCY),is(4.0));
assertThat(sample2.getFieldValue("1"),is(250.0));
assertThat(sample2.getFieldValue("2"),is(4.5));
assertThat(sample2.getFieldValue("4"),is(1.0));
assertThat(sample2.getFieldValue("7"),is(1.0));
final SolrDocument sample3 = results.get(2);
assertThat(sample3.getFieldValue(SolrFields.TrainingSet.RELEVANCY),is(5.0));
assertThat(sample3.getFieldValue("1"),is(450.0));
assertThat(sample3.getFieldValue("2"),is(5.0));
assertThat(sample3.getFieldValue("5"),is(1.0));
assertThat(sample3.getFieldValue("6"),is(1.0));
final SolrDocument sample4 = results.get(3);
assertThat(sample4.getFieldValue(SolrFields.TrainingSet.RELEVANCY),is(2.0));
assertThat(sample4.getFieldValue("1"),is(200.0));
assertThat(sample4.getFieldValue("2"),is(3.5));
assertThat(sample4.getFieldValue("3"),is(1.0));
assertThat(sample4.getFieldValue("8"),is(1.0));
}
示例13: doBoltActionTest
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
protected void doBoltActionTest() throws Exception {
// Spring @Autowired property at runtime
SolrBoltAction sba = new SolrBoltAction(cloudSolrClient);
sba.setUpdateRequestStrategy(new DefaultUpdateRequestStrategy());
sba.setMaxBufferSize(1); // to avoid buffering docs
// Mock the Storm tuple
String docId = "1";
TestDoc testDoc = new TestDoc(docId, "foo", 10);
Tuple mockTuple = mock(Tuple.class);
when(mockTuple.size()).thenReturn(2);
when(mockTuple.getString(0)).thenReturn(docId);
when(mockTuple.getValue(1)).thenReturn(testDoc);
SpringBolt.ExecuteResult result = sba.execute(mockTuple, null);
assertTrue(result == SpringBolt.ExecuteResult.ACK);
cloudSolrClient.commit();
// verify the object to Solr mapping worked correctly using reflection and dynamic fields
SolrQuery query = new SolrQuery("id:" + docId);
QueryResponse qr = cloudSolrClient.query(query);
SolrDocumentList results = qr.getResults();
assertTrue(results.getNumFound() == 1);
SolrDocument doc = results.get(0);
assertNotNull(doc);
assertEquals("foo", doc.getFirstValue("text_s"));
assertEquals(new Integer(testDoc.number), doc.getFirstValue("number_i"));
assertTrue(doc.getFirstValue("timestamp_tdt") != null);
}
示例14: doNestedDocTest
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
protected void doNestedDocTest() throws Exception {
SolrBoltAction sba = new SolrBoltAction(cloudSolrClient);
sba.setSolrInputDocumentMapper(new NestedDocumentMapper());
sba.setUpdateRequestStrategy(new DefaultUpdateRequestStrategy());
sba.setMaxBufferSize(1); // to avoid buffering docs
String docId = "1";
JSONArray jsonDocs = NestedDocumentMapperTest.loadNestedDocs();
Tuple mockTuple = mock(Tuple.class);
when(mockTuple.size()).thenReturn(2);
when(mockTuple.getString(0)).thenReturn(docId);
when(mockTuple.getValue(1)).thenReturn(jsonDocs.get(0));
SpringBolt.ExecuteResult result = sba.execute(mockTuple, null);
assertTrue(result == SpringBolt.ExecuteResult.ACK);
cloudSolrClient.commit();
// verify the object to Solr mapping worked correctly using reflection and dynamic fields
SolrQuery query = new SolrQuery("id:" + docId);
query.set("fl", "*,[child parentFilter=id:"+docId+" limit=100]");
QueryResponse qr = cloudSolrClient.query(query);
SolrDocumentList results = qr.getResults();
assertTrue(results.getNumFound() == 1);
SolrDocument doc = results.get(0);
assertNotNull(doc);
System.out.println("\n\n>> doc: "+doc+"\n\n");
if (doc.hasChildDocuments()) {
for (SolrDocument child : doc.getChildDocuments()) {
System.out.println("\n>> "+child+"\n");
}
} else {
System.out.println("no child documents returned");
}
}
示例15: assertOrder
import org.apache.solr.common.SolrDocumentList; //導入方法依賴的package包/類
private void assertOrder(QueryResponse rsp, String ... docs) throws Exception {
SolrDocumentList list = rsp.getResults();
for(int i=0; i<docs.length; i++) {
SolrDocument doc = list.get(i);
Object o = doc.getFieldValue("id");
if(!docs[i].equals(o)) {
throw new Exception("Order is not correct:"+o+"!="+docs[i]);
}
}
}