//获取Int
FieldCache.Ints ints = FieldCache.DEFAULT.getInts(AtomicReader reader, String field, boolean setDocsWithField);
//获取docId的域值
int value = ints.get(docId);
//获取string
BytesRef bytesRef = new BytesRef();
BinaryDocValues terms = FieldCache.DEFAULT.getTerms(AtomicReader reader, String field, boolean setDocsWithField);
terms.get(doc,bytesRef);
String value = bytesRef.utf8ToString();
Lucene 4.10.0
BinaryDocValues terms = getTerms(AtomicReader reader, String field, boolean setDocsWithField);
String value = terms.get(docId).utf8ToString();
//基于FieldCache的Filter
Filter f = FieldCacheRangeFilter.newIntRange("left", 0, 100, true, true);
Filter filter = new FieldCacheTermsFilter("type", new BytesRef[]{new BytesRef("science"), new BytesRef("it")});
注意的地方:
1. fieldCache中的字段值是从倒排表中读出来的,而不是从索引文件中存储的字段值,所以排序的字段必须设为索引字段2 .用来排序的字段在索引的时候不能拆分(tokenized),因为fieldCache数组中,每个文档只对应一个字段值,拆分的话,cache中只会保存在词典中靠后的值。
3 .fieldcache是lucene最占用的内存的部分,大部分内存溢出的错误都是由它而起,需要特别注意。