Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
ef7a48df
R
rails
项目概览
张重言
/
rails
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rails
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
GitCode(gitcode.net)2024年7月9日维护升级公告
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
ef7a48df
编写于
4月 16, 2013
作者:
X
Xavier Noria
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
let EXPLAIN use a thread locals registry [John J. Wang & Xavier Noria]
Closes #10198.
上级
0513f6ca
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
70 addition
and
46 deletion
+70
-46
activerecord/lib/active_record/explain.rb
activerecord/lib/active_record/explain.rb
+8
-7
activerecord/lib/active_record/explain_registry.rb
activerecord/lib/active_record/explain_registry.rb
+30
-0
activerecord/lib/active_record/explain_subscriber.rb
activerecord/lib/active_record/explain_subscriber.rb
+3
-2
activerecord/test/cases/adapters/postgresql/explain_test.rb
activerecord/test/cases/adapters/postgresql/explain_test.rb
+0
-7
activerecord/test/cases/explain_subscriber_test.rb
activerecord/test/cases/explain_subscriber_test.rb
+29
-30
未找到文件。
activerecord/lib/active_record/explain.rb
浏览文件 @
ef7a48df
require
'active_support/lazy_load_hooks'
require
'active_record/explain_registry'
module
ActiveRecord
module
Explain
# Relation#explain needs to be able to collect the queries.
# Executes the block with the collect flag enabled. Queries are collected
# asynchronously by the subscriber and returned.
def
collecting_queries_for_explain
# :nodoc:
current
=
Thread
.
current
original
,
current
[
:available_queries_for_explain
]
=
current
[
:available_queries_for_explain
],
[]
ExplainRegistry
.
collect
=
true
yield
return
current
[
:available_queries_for_explain
]
ExplainRegistry
.
queries
ensure
# Note that the return value above does not depend on this assignment.
current
[
:available_queries_for_explain
]
=
original
ExplainRegistry
.
reset
end
# Makes the adapter execute EXPLAIN for the tuples of queries and bindings.
# Returns a formatted string ready to be logged.
def
exec_explain
(
queries
)
# :nodoc:
str
=
queries
&&
queries
.
map
do
|
sql
,
bind
|
str
=
queries
.
map
do
|
sql
,
bind
|
[].
tap
do
|
msg
|
msg
<<
"EXPLAIN for:
#{
sql
}
"
unless
bind
.
empty?
...
...
@@ -31,6 +31,7 @@ def exec_explain(queries) # :nodoc:
def
str
.
inspect
self
end
str
end
end
...
...
activerecord/lib/active_record/explain_registry.rb
0 → 100644
浏览文件 @
ef7a48df
require
'active_support/per_thread_registry'
module
ActiveRecord
# This is a thread locals registry for EXPLAIN. For example
#
# ActiveRecord::ExplainRegistry.queries
#
# returns the collected queries local to the current thread.
#
# See the documentation of <tt>ActiveSupport::PerThreadRegistry</tt>
# for further details.
class
ExplainRegistry
extend
ActiveSupport
::
PerThreadRegistry
attr_accessor
:queries
,
:collect
def
initialize
reset
end
def
collect?
@collect
end
def
reset
@collect
=
false
@queries
=
[]
end
end
end
\ No newline at end of file
activerecord/lib/active_record/explain_subscriber.rb
浏览文件 @
ef7a48df
require
'active_support/notifications'
require
'active_record/explain_registry'
module
ActiveRecord
class
ExplainSubscriber
# :nodoc:
...
...
@@ -7,8 +8,8 @@ def start(name, id, payload)
end
def
finish
(
name
,
id
,
payload
)
if
queries
=
Thread
.
current
[
:available_queries_for_explain
]
queries
<<
payload
.
values_at
(
:sql
,
:binds
)
unless
ignore_payload?
(
payload
)
if
ExplainRegistry
.
collect?
&&
!
ignore_payload?
(
payload
)
ExplainRegistry
.
queries
<<
payload
.
values_at
(
:sql
,
:binds
)
end
end
...
...
activerecord/test/cases/adapters/postgresql/explain_test.rb
浏览文件 @
ef7a48df
...
...
@@ -22,13 +22,6 @@ def test_explain_with_eager_loading
assert_match
%(EXPLAIN for: SELECT "audit_logs".* FROM "audit_logs" WHERE "audit_logs"."developer_id" IN (1))
,
explain
assert_match
%(Seq Scan on audit_logs)
,
explain
end
def
test_dont_explain_for_set_search_path
queries
=
Thread
.
current
[
:available_queries_for_explain
]
=
[]
ActiveRecord
::
Base
.
connection
.
schema_search_path
=
"public"
assert
queries
.
empty?
end
end
end
end
...
...
activerecord/test/cases/explain_subscriber_test.rb
浏览文件 @
ef7a48df
require
'cases/helper'
require
'active_record/explain_subscriber'
require
'active_record/explain_registry'
if
ActiveRecord
::
Base
.
connection
.
supports_explain?
class
ExplainSubscriberTest
<
ActiveRecord
::
TestCase
SUBSCRIBER
=
ActiveRecord
::
ExplainSubscriber
.
new
def
test_collects_nothing_if_available_queries_for_explain_is_nil
with_queries
(
nil
)
do
SUBSCRIBER
.
finish
(
nil
,
nil
,
{})
assert_nil
Thread
.
current
[
:available_queries_for_explain
]
end
def
setup
ActiveRecord
::
ExplainRegistry
.
reset
ActiveRecord
::
ExplainRegistry
.
collect
=
true
end
def
test_collects_nothing_if_the_payload_has_an_exception
with_queries
([])
do
|
queries
|
SUBSCRIBER
.
finish
(
nil
,
nil
,
:exception
=>
Exception
.
new
)
assert
queries
.
empty?
end
SUBSCRIBER
.
finish
(
nil
,
nil
,
exception:
Exception
.
new
)
assert
queries
.
empty?
end
def
test_collects_nothing_for_ignored_payloads
with_queries
([])
do
|
queries
|
ActiveRecord
::
ExplainSubscriber
::
IGNORED_PAYLOADS
.
each
do
|
ip
|
SUBSCRIBER
.
finish
(
nil
,
nil
,
:name
=>
ip
)
end
assert
queries
.
empty?
ActiveRecord
::
ExplainSubscriber
::
IGNORED_PAYLOADS
.
each
do
|
ip
|
SUBSCRIBER
.
finish
(
nil
,
nil
,
name:
ip
)
end
assert
queries
.
empty?
end
def
test_collects_nothing_if_collect_is_false
ActiveRecord
::
ExplainRegistry
.
collect
=
false
SUBSCRIBER
.
finish
(
nil
,
nil
,
name:
'SQL'
,
sql:
'select 1 from users'
,
binds:
[
1
,
2
])
assert
queries
.
empty?
end
def
test_collects_pairs_of_queries_and_binds
sql
=
'select 1 from users'
binds
=
[
1
,
2
]
with_queries
([])
do
|
queries
|
SUBSCRIBER
.
finish
(
nil
,
nil
,
:name
=>
'SQL'
,
:sql
=>
sql
,
:binds
=>
binds
)
assert_equal
1
,
queries
.
size
assert_equal
sql
,
queries
[
0
][
0
]
assert_equal
binds
,
queries
[
0
][
1
]
end
SUBSCRIBER
.
finish
(
nil
,
nil
,
name:
'SQL'
,
sql:
sql
,
binds:
binds
)
assert_equal
1
,
queries
.
size
assert_equal
sql
,
queries
[
0
][
0
]
assert_equal
binds
,
queries
[
0
][
1
]
end
def
test_collects_nothing_if_unexplained_sqls
with_queries
([])
do
|
queries
|
SUBSCRIBER
.
finish
(
nil
,
nil
,
:name
=>
'SQL'
,
:sql
=>
'SHOW max_identifier_length'
)
assert
queries
.
empty?
end
def
test_collects_nothing_if_the_statement_is_not_whitelisted
SUBSCRIBER
.
finish
(
nil
,
nil
,
name:
'SQL'
,
sql:
'SHOW max_identifier_length'
)
assert
queries
.
empty?
end
def
teardown
ActiveRecord
::
ExplainRegistry
.
reset
end
def
with_queries
(
queries
)
Thread
.
current
[
:available_queries_for_explain
]
=
queries
yield
queries
ensure
Thread
.
current
[
:available_queries_for_explain
]
=
nil
def
queries
ActiveRecord
::
ExplainRegistry
.
queries
end
end
end
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录