Skip to content

Commit

Permalink
Add PgConnection::is_explain_available
Browse files Browse the repository at this point in the history
  • Loading branch information
Suficio authored and abonander committed Dec 24, 2024
1 parent 20bccf8 commit fdd4663
Showing 1 changed file with 10 additions and 5 deletions.
15 changes: 10 additions & 5 deletions sqlx-postgres/src/connection/describe.rs
Original file line number Diff line number Diff line change
Expand Up @@ -412,6 +412,15 @@ WHERE rngtypid = $1
Ok(array_oid)
}

/// Check whether EXPLAIN statements are supported by the current connection
fn is_explain_available(&self) -> bool {
let parameter_statuses = &self.inner.stream.parameter_statuses;
let is_cockroachdb = parameter_statuses.contains_key("crdb_version");
let is_materialize = parameter_statuses.contains_key("mz_version");
let is_questdb = parameter_statuses.contains_key("questdb_version");
!is_cockroachdb && !is_materialize && !is_questdb
}

pub(crate) async fn get_nullable_for_columns(
&mut self,
stmt_id: StatementId,
Expand Down Expand Up @@ -487,11 +496,7 @@ WHERE rngtypid = $1
})?;

// If the server doesn't support EXPLAIN statements, skip this step (#1248).
let parameter_statuses = &self.inner.stream.parameter_statuses;
let is_cockroachdb = parameter_statuses.contains_key("crdb_version");
let is_materialize = parameter_statuses.contains_key("mz_version");
let is_questdb = parameter_statuses.contains_key("questdb_version");
if !is_cockroachdb && !is_materialize && !is_questdb {
if self.is_explain_available() {
// patch up our null inference with data from EXPLAIN
let nullable_patch = self
.nullables_from_explain(stmt_id, meta.parameters.len())
Expand Down

0 comments on commit fdd4663

Please sign in to comment.