Query DSL: don't cache type filter in DocumentMapper

If we cache the type filter and we e.g. set its boost which is now settable on all queries, the boost will change for all subsequent queries. We should rather create a new query every time.
This commit is contained in:
javanna 2015-07-24 18:37:17 +02:00 committed by Luca Cavanna
parent db5d73a617
commit cf570ac5bd
1 changed files with 1 additions and 4 deletions

View File

@ -168,8 +168,6 @@ public class DocumentMapper implements ToXContent {
private boolean hasNestedObjects = false; private boolean hasNestedObjects = false;
private final Query typeFilter;
private final ReleasableLock mappingWriteLock; private final ReleasableLock mappingWriteLock;
private final ReentrantReadWriteLock mappingLock; private final ReentrantReadWriteLock mappingLock;
@ -190,7 +188,6 @@ public class DocumentMapper implements ToXContent {
meta); meta);
this.documentParser = new DocumentParser(indexSettings, docMapperParser, this, new ReleasableLock(mappingLock.readLock())); this.documentParser = new DocumentParser(indexSettings, docMapperParser, this, new ReleasableLock(mappingLock.readLock()));
this.typeFilter = typeMapper().fieldType().termQuery(type, null);
this.mappingWriteLock = new ReleasableLock(mappingLock.writeLock()); this.mappingWriteLock = new ReleasableLock(mappingLock.writeLock());
this.mappingLock = mappingLock; this.mappingLock = mappingLock;
@ -307,7 +304,7 @@ public class DocumentMapper implements ToXContent {
} }
public Query typeFilter() { public Query typeFilter() {
return this.typeFilter; return typeMapper().fieldType().termQuery(type, null);
} }
public boolean hasNestedObjects() { public boolean hasNestedObjects() {