Module: PgHero::Methods::Explain

Included in:
Database
Defined in:
lib/pghero/methods/explain.rb

Instance Method Summary collapse

Instance Method Details

#explain(sql) ⇒ Object



4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
# File 'lib/pghero/methods/explain.rb', line 4

def explain(sql)
  sql = squish(sql)
  explanation = nil
  explain_safe = explain_safe?

  # use transaction for safety
  connection_model.transaction do
    if !explain_safe && (sql.sub(/;\z/, "").include?(";") || sql.upcase.include?("COMMIT"))
      raise ActiveRecord::StatementInvalid, "Unsafe statement"
    end
    explanation = select_all("EXPLAIN #{sql}").map { |v| v["QUERY PLAN"] }.join("\n")
    raise ActiveRecord::Rollback
  end

  explanation
end