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:
parent
db5d73a617
commit
cf570ac5bd
|
@ -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() {
|
||||||
|
|
Loading…
Reference in New Issue