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 |