From 0f2f8eedea38ecbd48912607559fd75eaaa55874 Mon Sep 17 00:00:00 2001 From: Tim Diekmann Date: Thu, 17 Oct 2024 14:26:00 +0200 Subject: [PATCH] Attempt to fix traversal logic --- .../store/postgres/knowledge/entity/read.rs | 21 +++++++------------ .../store/postgres/ontology/entity_type.rs | 2 +- 2 files changed, 8 insertions(+), 15 deletions(-) diff --git a/apps/hash-graph/libs/graph/src/store/postgres/knowledge/entity/read.rs b/apps/hash-graph/libs/graph/src/store/postgres/knowledge/entity/read.rs index 1a24cc1c377..67a858249d6 100644 --- a/apps/hash-graph/libs/graph/src/store/postgres/knowledge/entity/read.rs +++ b/apps/hash-graph/libs/graph/src/store/postgres/knowledge/entity/read.rs @@ -96,18 +96,11 @@ where TimeAxis::TransactionTime => ("decision_time", "transaction_time"), }; - let table = if depth == Some(0) { - "entity_is_of_type" - } else { - "closed_entity_is_of_type" - }; - - let where_statement = match depth { - Some(depth) if depth != 0 => Cow::Owned(format!( + let where_statement = depth.map_or(Cow::Borrowed(""), |depth| { + Cow::Owned(format!( "WHERE closed_entity_is_of_type.inheritance_depth <= {depth}" - )), - _ => Cow::Borrowed(""), - }; + )) + }); Ok(self .client @@ -131,11 +124,11 @@ where AND source.web_id = filter.web_id AND source.entity_uuid = filter.entity_uuid - JOIN {table} - ON source.entity_edition_id = {table}.entity_edition_id + JOIN closed_entity_is_of_type + ON source.entity_edition_id = closed_entity_is_of_type.entity_edition_id JOIN ontology_ids - ON {table}.entity_type_ontology_id = ontology_ids.ontology_id + ON closed_entity_is_of_type.entity_type_ontology_id = ontology_ids.ontology_id {where_statement}; "# diff --git a/apps/hash-graph/libs/graph/src/store/postgres/ontology/entity_type.rs b/apps/hash-graph/libs/graph/src/store/postgres/ontology/entity_type.rs index ece246e7476..9b46e5b8f7e 100644 --- a/apps/hash-graph/libs/graph/src/store/postgres/ontology/entity_type.rs +++ b/apps/hash-graph/libs/graph/src/store/postgres/ontology/entity_type.rs @@ -1179,7 +1179,7 @@ where #[tracing::instrument(level = "info", skip(self))] async fn reindex_entity_type_cache(&mut self) -> Result<(), UpdateError> { - tracing::info!("Reindexing data type cache"); + tracing::info!("Reindexing entity type cache"); let transaction = self.transaction().await.change_context(UpdateError)?; // We remove the data from the reference tables first