Один из способов сделать это с помощью пользовательского фильтра. Например, если вы хотите фильтровать по идентификаторам для вашего класса домена, вы бы добавили идентификатор в конфигурацию поиска для класса домена:
static searchable = {
id name: "id"
}
Тогда вы бы написали свой собственный фильтр (который может быть в [project] / src / java):
import org.apache.lucene.search.Filter;
import java.util.BitSet;
import org.apache.lucene.index.TermDocs;
import org.apache.lucene.index.Term;
import org.apache.lucene.index.IndexReader;
import java.io.IOException;
import java.util.List;
public class IdFilter extends Filter {
private List<String> ids;
public IdFilter(List<String> ids) {
this.ids = ids;
}
public BitSet bits(IndexReader reader) throws IOException {
BitSet bits = new BitSet(reader.maxDoc());
int[] docs = new int[1];
int[] freqs = new int[1];
for( String id : ids ) {
if (id != null) {
TermDocs termDocs = reader.termDocs(new Term("id", id ) );
int count = termDocs.read(docs, freqs);
if (count == 1) {
bits.set(docs[0]);
}
}
}
return bits;
}
}
Тогда вы бы добавили фильтр в качестве аргумента для своего поиска (обязательно импортировав класс Filter, если он находится в другом пакете):
def theSearchResult = MyDomainClass.search(
{
must( queryString(params.q) )
},
params,
filter: new IdFilter( [ "1" ] ))
Здесь я просто создаю жестко закодированный список с одним значением «1», но вы можете получить список идентификаторов из базы данных, из предыдущего поиска или где-либо еще.
Вы можете легко абстрагировать фильтр, который я должен взять в названии термина в названии конструктора, а затем передать «имя» так, как вы хотите.