Class: ActiveRecord::ExplainSubscriber
- Inherits:
-
Object
- Object
- ActiveRecord::ExplainSubscriber
- Defined in:
- lib/active_record/explain_subscriber.rb
Overview
:nodoc:
Constant Summary collapse
- IGNORED_PAYLOADS =
SCHEMA queries cannot be EXPLAINed, also we do not want to run EXPLAIN on our own EXPLAINs now matter how loopingly beautiful that would be.
On the other hand, we want to monitor the performance of our real database queries, not the performance of the access to the query cache.
%w(SCHEMA EXPLAIN CACHE)
- EXPLAINED_SQLS =
/\A\s*(select|update|delete|insert)\b/i
Instance Method Summary collapse
Instance Method Details
#call(*args) ⇒ Object
5 6 7 8 9 10 |
# File 'lib/active_record/explain_subscriber.rb', line 5 def call(*args) if queries = Thread.current[:available_queries_for_explain] payload = args.last queries << payload.values_at(:sql, :binds) unless ignore_payload?(payload) end end |
#ignore_payload?(payload) ⇒ Boolean
19 20 21 |
# File 'lib/active_record/explain_subscriber.rb', line 19 def ignore_payload?(payload) payload[:exception] || IGNORED_PAYLOADS.include?(payload[:name]) || payload[:sql] !~ EXPLAINED_SQLS end |