diff --git a/crates/torii/grpc/src/server/mod.rs b/crates/torii/grpc/src/server/mod.rs index bb04979b83..113832b1e8 100644 --- a/crates/torii/grpc/src/server/mod.rs +++ b/crates/torii/grpc/src/server/mod.rs @@ -764,16 +764,31 @@ impl DojoWorld { let (where_clause, having_clause, join_clause, bind_values) = build_composite_clause(table, model_relation_table, &composite)?; - let count_query = format!( - r#" - SELECT COUNT(DISTINCT [{table}].id) - FROM [{table}] - JOIN {model_relation_table} ON [{table}].id = {model_relation_table}.entity_id - {join_clause} - {where_clause} - {having_clause} - "#, - ); + let count_query = if !having_clause.is_empty() { + format!( + r#" + SELECT COUNT(*) FROM ( + SELECT [{table}].id + FROM [{table}] + JOIN {model_relation_table} ON [{table}].id = {model_relation_table}.entity_id + {join_clause} + {where_clause} + GROUP BY [{table}].id + {having_clause} + ) as filtered_count + "# + ) + } else { + format!( + r#" + SELECT COUNT(DISTINCT [{table}].id) + FROM [{table}] + JOIN {model_relation_table} ON [{table}].id = {model_relation_table}.entity_id + {join_clause} + {where_clause} + "# + ) + }; let mut count_query = sqlx::query_scalar::<_, u32>(&count_query); for value in &bind_values { @@ -1146,7 +1161,7 @@ fn build_keys_pattern(clause: &proto::types::KeysClause) -> Result 0", + model_id + )); + } } ClauseType::Member(member) => { let comparison_operator = ComparisonOperator::from_repr(member.operator as usize)