From 1ca356774eef6b67a7e8e6c98c18354c58be6b2a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mario=20Alejandro=20Montoya=20Corte=CC=81s?= Date: Tue, 24 Dec 2024 11:23:18 -0500 Subject: [PATCH] Show labels only if requested --- crates/physical-plan/src/plan.rs | 30 ++++++++++++++--------------- crates/physical-plan/src/printer.rs | 15 ++++++++++++--- 2 files changed, 27 insertions(+), 18 deletions(-) diff --git a/crates/physical-plan/src/plan.rs b/crates/physical-plan/src/plan.rs index 3319e0a67e5..b662e0a6278 100644 --- a/crates/physical-plan/src/plan.rs +++ b/crates/physical-plan/src/plan.rs @@ -1954,7 +1954,7 @@ mod tests { "SELECT * FROM p", expect![ r#" - Seq Scan on p:1 + Seq Scan on p Output: id, name"# ], ); @@ -1968,7 +1968,7 @@ mod tests { "SELECT * FROM p as b", expect![ r#" - Seq Scan on p:1 + Seq Scan on p Output: id, name"# ], ); @@ -1994,7 +1994,7 @@ mod tests { "SELECT id FROM p", expect![ r#" - Seq Scan on p:1 + Seq Scan on p Output: p.id"# ], ); @@ -2005,8 +2005,8 @@ mod tests { expect![ r#" Nested Loop - -> Seq Scan on m:1 - -> Seq Scan on p:2 + -> Seq Scan on m + -> Seq Scan on p Output: p.id, m.employee"# ], ); @@ -2020,7 +2020,7 @@ mod tests { &db, "SELECT * FROM p WHERE id = 1", expect![[r#" - Seq Scan on p:1 + Seq Scan on p Filter: (p.id = U64(1)) Output: id, name"#]], ); @@ -2029,9 +2029,9 @@ mod tests { &db, "SELECT * FROM p WHERE id = 1 AND id =2 OR name = 'jhon'", expect![[r#" - Seq Scan on p:1 - Filter: (p.id = U64(1) AND p.id = U64(2) OR p.name = String("jhon")) - Output: id, name"#]], + Seq Scan on p + Filter: (p.id = U64(1) AND p.id = U64(2) OR p.name = String("jhon")) + Output: id, name"#]], ); } @@ -2043,7 +2043,7 @@ mod tests { &db, "SELECT m.* FROM m WHERE employee = 1", expect![[r#" - Index Scan using Index id 0: (employee) on m:1 + Index Scan using Index id 0: (employee) on m Index Cond: (m.employee = U64(1)) Output: employee, manager"#]], ); @@ -2058,8 +2058,8 @@ mod tests { "SELECT p.* FROM m JOIN p", expect![[r#" Nested Loop - -> Seq Scan on m:1 - -> Seq Scan on p:2 + -> Seq Scan on m + -> Seq Scan on p Output: id, name"#]], ); } @@ -2073,8 +2073,8 @@ mod tests { "SELECT p.* FROM m JOIN p ON m.employee = p.id where m.employee = 1", expect![[r#" Hash Join: All - -> Seq Scan on m:1 - -> Seq Scan on p:2 + -> Seq Scan on m + -> Seq Scan on p Inner Unique: false Hash Cond: (m.employee = p.id) Filter: (m.employee = U64(1)) @@ -2091,7 +2091,7 @@ mod tests { "SELECT p.* FROM m JOIN p ON m.employee = p.id", expect![[r#" Index Join: Rhs - -> Seq Scan on m:1 + -> Seq Scan on m Inner Unique: true Index Cond: (m.employee = p.id) Output: employee, manager"#]], diff --git a/crates/physical-plan/src/printer.rs b/crates/physical-plan/src/printer.rs index f0e86a1a94c..9e855aa94db 100644 --- a/crates/physical-plan/src/printer.rs +++ b/crates/physical-plan/src/printer.rs @@ -420,7 +420,11 @@ impl<'a> fmt::Display for Explain<'a> { write!(f, "{:ident$}{arrow}", "")?; match line { Line::TableScan { table, label, ident: _ } => { - write!(f, "Seq Scan on {}:{}", table, label.0)?; + if self.show_schema { + write!(f, "Seq Scan on {}:{}", table, label.0)?; + } else { + write!(f, "Seq Scan on {}", table)?; + } } Line::IxScan { table_name, @@ -428,7 +432,11 @@ impl<'a> fmt::Display for Explain<'a> { label, ident: _, } => { - write!(f, "Index Scan using {index} on {table_name}:{}", label.0)?; + if self.show_schema { + write!(f, "Index Scan using {index} on {table_name}:{}", label.0)?; + } else { + write!(f, "Index Scan using {index} on {table_name}")?; + } } Line::Filter { expr, ident: _ } => { write!( @@ -503,7 +511,8 @@ impl<'a> fmt::Display for Explain<'a> { } if self.show_timings { - write!(f, "Planning Time: {:?}", ctx.planning_time)?; + let end = if self.show_schema { "\n" } else { "" }; + write!(f, "Planning Time: {:?}{end}", ctx.planning_time)?; } if self.show_schema {