本文整理匯總了Java中org.apache.lucene.search.Sort.setSort方法的典型用法代碼示例。如果您正苦於以下問題:Java Sort.setSort方法的具體用法?Java Sort.setSort怎麽用?Java Sort.setSort使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.apache.lucene.search.Sort
的用法示例。
在下文中一共展示了Sort.setSort方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: testEmptyIndex
import org.apache.lucene.search.Sort; //導入方法依賴的package包/類
public void testEmptyIndex() throws Exception {
IndexSearcher empty = newSearcher(new MultiReader());
Query query = new TermQuery(new Term("contents", "foo"));
Sort sort = new Sort();
sort.setSort(new SortedSetSortField("sortedset", false));
TopDocs td = empty.search(query, null, 10, sort, true, true);
assertEquals(0, td.totalHits);
// for an empty index, any selector should work
for (SortedSetSortField.Selector v : SortedSetSortField.Selector.values()) {
sort.setSort(new SortedSetSortField("sortedset", false, v));
td = empty.search(query, null, 10, sort, true, true);
assertEquals(0, td.totalHits);
}
}
示例2: testEmptyIndex
import org.apache.lucene.search.Sort; //導入方法依賴的package包/類
public void testEmptyIndex() throws Exception {
IndexSearcher empty = newSearcher(new MultiReader());
Query query = new TermQuery(new Term("contents", "foo"));
Sort sort = new Sort();
sort.setSort(new SortedNumericSortField("sortednumeric", SortField.Type.LONG));
TopDocs td = empty.search(query, null, 10, sort, true, true);
assertEquals(0, td.totalHits);
// for an empty index, any selector should work
for (SortedNumericSelector.Type v : SortedNumericSelector.Type.values()) {
sort.setSort(new SortedNumericSortField("sortednumeric", SortField.Type.LONG, false, v));
td = empty.search(query, null, 10, sort, true, true);
assertEquals(0, td.totalHits);
}
}
示例3: clearSorting
import org.apache.lucene.search.Sort; //導入方法依賴的package包/類
@SuppressWarnings( "unchecked" )
public F clearSorting( ) {
this.sortFields = "";
this.sortDirections = "";
sortObj = new Sort( );
sortObj.setSort( new SortField[0] );
updateSorting = updateParamMap = true;
return ( F )this;
}
示例4: testSearchIndex
import org.apache.lucene.search.Sort; //導入方法依賴的package包/類
@Test
public void testSearchIndex() throws Exception {
try (LuceneSearchIndex index = new LuceneSearchIndex("", "test", true)) {
final Document doc1 = new Document();
doc1.add(new StringField(IndexedStore.ID_FIELD_NAME, new BytesRef("1".getBytes()), Store.YES));
doc1.add(new StringField("ds", "space1.ds1", Field.Store.NO));
doc1.add(new StringField("job", "job1", Field.Store.YES));
// since we want to sort on version add docvalues
doc1.add(new StringField("version", "v1", Field.Store.NO));
doc1.add(new SortedDocValuesField("version", new BytesRef("v1")));
doc1.add(new StringField("foo", "bar1", Store.NO));
doc1.add(new SortedDocValuesField("foo", new BytesRef("bar1")));
final Document doc2 = new Document();
doc2.add(new StringField(IndexedStore.ID_FIELD_NAME, new BytesRef("2".getBytes()), Store.YES));
doc2.add(new StringField("ds", "space1.ds1", Field.Store.NO));
doc2.add(new StringField("job", "job3", Field.Store.YES));
doc2.add(new StringField("version", "v2", Field.Store.NO));
doc2.add(new SortedDocValuesField("version", new BytesRef("v2")));
doc2.add(new StringField("foo", "bar2", Store.NO));
doc2.add(new SortedDocValuesField("foo", new BytesRef("bar2")));
final Document doc3 = new Document();
doc3.add(new StringField(IndexedStore.ID_FIELD_NAME, new BytesRef("3".getBytes()), Store.YES));
doc3.add(new StringField("ds", "space2.ds2", Field.Store.NO));
doc3.add(new StringField("job", "job2", Field.Store.YES));
doc3.add(new StringField("version", "v1", Field.Store.NO));
doc3.add(new SortedDocValuesField("version", new BytesRef("v1")));
index.add(doc1);
assertEquals(1, index.count(new TermQuery(new Term("ds", "space1.ds1"))));
BooleanQuery.Builder builder = new BooleanQuery.Builder();
builder.add(new BooleanClause(new TermQuery(new Term("ds", "space1.ds1")), BooleanClause.Occur.MUST));
builder.add(new BooleanClause(new TermQuery(new Term("version", "v1")), BooleanClause.Occur.MUST));
assertEquals(1, index.count(builder.build()));
assertEquals(0, index.count(new TermQuery(new Term("ds", "space2.ds2"))));
assertEquals(0, index.count(new TermQuery(new Term("version", "v2"))));
builder = new BooleanQuery.Builder();
builder.add(new BooleanClause(new TermQuery(new Term("ds", "space1.ds1")), BooleanClause.Occur.MUST));
builder.add(new BooleanClause(new TermQuery(new Term("version", "v2")), BooleanClause.Occur.MUST));
assertEquals(0, index.count(builder.build()));
assertEquals(1, index.count(new TermsQuery(new Term("ds", "space1.ds1"), new Term("version1", "v2"))));
index.add(doc2);
index.add(doc3);
assertEquals(2, index.count(new TermQuery(new Term("ds", "space1.ds1"))));
assertEquals(1, index.count(new TermQuery(new Term("ds", "space2.ds2"))));
builder = new BooleanQuery.Builder();
builder.add(new BooleanClause(new TermQuery(new Term("ds", "space2.ds2")), BooleanClause.Occur.MUST));
builder.add(new BooleanClause(new TermQuery(new Term("version", "v1")), BooleanClause.Occur.MUST));
assertEquals(1, index.count(builder.build()));
builder = new BooleanQuery.Builder();
builder.add(new BooleanClause(new TermQuery(new Term("ds", "space1.ds1")), BooleanClause.Occur.MUST));
builder.add(new BooleanClause(new TermQuery(new Term("version", "v1")), BooleanClause.Occur.MUST));
assertEquals(1, index.count(builder.build()));
Sort sorter = new Sort();
sorter.setSort(new SortField("version", SortField.Type.STRING));
Collection<Document> documents = index.searchForDocuments(new TermQuery(new Term("ds", "space1.ds1")), 1000, sorter);
assertEquals(2, documents.size());
// exists queries
assertEquals(2, index.count(LuceneQueryConverter.INSTANCE.toLuceneQuery(SearchQueryUtils.newExistsQuery("foo"))));
assertEquals(1, index.count(LuceneQueryConverter.INSTANCE.toLuceneQuery(SearchQueryUtils.newDoesNotExistQuery("foo"))));
}
}
示例5: testCollationKeySort
import org.apache.lucene.search.Sort; //導入方法依賴的package包/類
public void testCollationKeySort(Analyzer usAnalyzer,
Analyzer franceAnalyzer,
Analyzer swedenAnalyzer,
Analyzer denmarkAnalyzer,
String usResult,
String frResult,
String svResult,
String dkResult) throws Exception {
Directory indexStore = newDirectory();
IndexWriter writer = new IndexWriter(indexStore, new IndexWriterConfig(
TEST_VERSION_CURRENT, new MockAnalyzer(random(), MockTokenizer.WHITESPACE, false)));
// document data:
// the tracer field is used to determine which document was hit
String[][] sortData = new String[][] {
// tracer contents US France Sweden (sv_SE) Denmark (da_DK)
{ "A", "x", "p\u00EAche", "p\u00EAche", "p\u00EAche", "p\u00EAche" },
{ "B", "y", "HAT", "HAT", "HAT", "HAT" },
{ "C", "x", "p\u00E9ch\u00E9", "p\u00E9ch\u00E9", "p\u00E9ch\u00E9", "p\u00E9ch\u00E9" },
{ "D", "y", "HUT", "HUT", "HUT", "HUT" },
{ "E", "x", "peach", "peach", "peach", "peach" },
{ "F", "y", "H\u00C5T", "H\u00C5T", "H\u00C5T", "H\u00C5T" },
{ "G", "x", "sin", "sin", "sin", "sin" },
{ "H", "y", "H\u00D8T", "H\u00D8T", "H\u00D8T", "H\u00D8T" },
{ "I", "x", "s\u00EDn", "s\u00EDn", "s\u00EDn", "s\u00EDn" },
{ "J", "y", "HOT", "HOT", "HOT", "HOT" },
};
FieldType customType = new FieldType();
customType.setStored(true);
for (int i = 0 ; i < sortData.length ; ++i) {
Document doc = new Document();
doc.add(new Field("tracer", sortData[i][0], customType));
doc.add(new TextField("contents", sortData[i][1], Field.Store.NO));
if (sortData[i][2] != null)
doc.add(new TextField("US", usAnalyzer.tokenStream("US", sortData[i][2])));
if (sortData[i][3] != null)
doc.add(new TextField("France", franceAnalyzer.tokenStream("France", sortData[i][3])));
if (sortData[i][4] != null)
doc.add(new TextField("Sweden", swedenAnalyzer.tokenStream("Sweden", sortData[i][4])));
if (sortData[i][5] != null)
doc.add(new TextField("Denmark", denmarkAnalyzer.tokenStream("Denmark", sortData[i][5])));
writer.addDocument(doc);
}
writer.forceMerge(1);
writer.close();
IndexReader reader = DirectoryReader.open(indexStore);
IndexSearcher searcher = new IndexSearcher(reader);
Sort sort = new Sort();
Query queryX = new TermQuery(new Term ("contents", "x"));
Query queryY = new TermQuery(new Term ("contents", "y"));
sort.setSort(new SortField("US", SortField.Type.STRING));
assertMatches(searcher, queryY, sort, usResult);
sort.setSort(new SortField("France", SortField.Type.STRING));
assertMatches(searcher, queryX, sort, frResult);
sort.setSort(new SortField("Sweden", SortField.Type.STRING));
assertMatches(searcher, queryY, sort, svResult);
sort.setSort(new SortField("Denmark", SortField.Type.STRING));
assertMatches(searcher, queryY, sort, dkResult);
reader.close();
indexStore.close();
}
示例6: defineOrder
import org.apache.lucene.search.Sort; //導入方法依賴的package包/類
public <T> void defineOrder(RestSearchKey key, FullTextQuery fullTextQuery) {
String[] orderBy = key.getOrders();
SortField[] sortFields = new SortField[orderBy.length];
Sort sort = new Sort();
for(int i = 0; i < orderBy.length; i++) {
sortFields[i] = key.isDesc() ? new SortField(orderBy[i], SortField.STRING, false) : new SortField(orderBy[i], SortField.STRING, true);
}
sort.setSort(sortFields);
fullTextQuery.setSort(sort);
}