perf: limit reindex to when exact_attributes changes

This commit is contained in:
Gregory Conrad 2022-11-23 15:50:53 -05:00
parent 57c9f03e51
commit d19c8672bb
2 changed files with 18 additions and 10 deletions

View File

@ -1145,9 +1145,8 @@ impl Index {
} }
/// Clears the exact attributes from the store. /// Clears the exact attributes from the store.
pub(crate) fn delete_exact_attributes(&self, txn: &mut RwTxn) -> Result<()> { pub(crate) fn delete_exact_attributes(&self, txn: &mut RwTxn) -> Result<bool> {
self.main.delete::<_, Str>(txn, main_key::EXACT_ATTRIBUTES)?; Ok(self.main.delete::<_, Str>(txn, main_key::EXACT_ATTRIBUTES)?)
Ok(())
} }
pub fn max_values_per_facet(&self, txn: &RoTxn) -> heed::Result<Option<usize>> { pub fn max_values_per_facet(&self, txn: &RoTxn) -> heed::Result<Option<usize>> {

View File

@ -465,14 +465,23 @@ impl<'a, 't, 'u, 'i> Settings<'a, 't, 'u, 'i> {
fn update_exact_attributes(&mut self) -> Result<bool> { fn update_exact_attributes(&mut self) -> Result<bool> {
match self.exact_attributes { match self.exact_attributes {
Setting::Set(ref attrs) => { Setting::Set(ref attrs) => {
let attrs = attrs.iter().map(String::as_str).collect::<Vec<_>>(); let old_attrs = self
self.index.put_exact_attributes(self.wtxn, &attrs)?; .index
Ok(true) .exact_attributes(self.wtxn)?
} .iter()
Setting::Reset => { .cloned()
self.index.delete_exact_attributes(self.wtxn)?; .map(String::from)
Ok(true) .collect::<HashSet<String>>();
if attrs != &old_attrs {
let attrs = attrs.iter().map(String::as_str).collect::<Vec<_>>();
self.index.put_exact_attributes(self.wtxn, &attrs)?;
Ok(true)
} else {
Ok(false)
}
} }
Setting::Reset => Ok(self.index.delete_exact_attributes(self.wtxn)?),
Setting::NotSet => Ok(false), Setting::NotSet => Ok(false),
} }
} }