似乎我原来的建议有点缺失set()
方法,为了添加文档值:
@Override
public void set(String name, Object value, Document document, LuceneOptions luceneOptions) {
if ( value != null ) {
int ordinal = getOrdinal(value.toString());
luceneOptions.addNumericFieldToDocument(name, ordinal, document);
// ADD THIS
luceneOptions.addNumericDocValuesFieldToDocument(name, ordinal, document);
}
}
最重要的是,如果您需要使用该字段进行排序和投影,我建议声明two字段。否则投影将返回整数,这不是您想要的。
所以,这样做:
@Indexed
@Entity
@Table(name = "LK_CONTACT_TYPE")
public class ContactTypeEntity {
@Id
@Column(name = "ID")
@DocumentId
Integer id;
@SortableField
// CHANGE THESE TWO LINES
@Field(store = Store.YES)
@Field(name = "name_sort", bridge = @FieldBridge(impl = ContactTypeComparator.class))
@Column(name = "NAME")
String name;
getter() .. setter()..
}
@Indexed
@Entity
@Table(name = "DIRECTORY")
public class DirectoryEntity {
....
// CHANGE THIS LINE
@IndexedEmbedded(prefix = "contactType.", includePaths = {"id", "name", "name_sort"})
@ManyToOne
@JoinColumn(name = "CONTACT_TYPE")
private ContactTypeEntity contactType;
getter() ... setter()...
}
public class ContactTypeComparator implements MetadataProvidingFieldBridge, TwoWayStringBridge {
@Override
public void set(String name, Object value, Document document, LuceneOptions luceneOptions) {
if ( value != null ) {
int ordinal = getOrdinal(value.toString());
luceneOptions.addNumericFieldToDocument(name, ordinal, document);
// ADD THIS LINE
luceneOptions.addNumericDocValuesFieldToDocument(name, ordinal, document);
}
}
@Override
public void configureFieldMetadata(String name, FieldMetadataBuilder builder) {
builder.field(name, FieldType.INTEGER).sortable(true);
}
private int getOrdinal(ContactType value) {
switch( value ) {
case PBX: return 0;
case TEL: return 1;
case GSM: return 2;
case FAX: return 3;
default: return 4;
}
}
@Override
public Object get(String name, Document document) {
return document.get( name );
}
@Override
public String objectToString(Object object) {
return object.toString();
}
}
然后像这样查询:
...
query.setSort(queryBuilder.sort().byScore().andByField("contactType.name_sort").createSort());
query.setProjection(... , "contactType.name",...);
...