Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
8a1be228
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,发现更多精彩内容 >>
提交
8a1be228
编写于
1月 20, 2010
作者:
P
Pratik Naik
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use unscoped instead of with_exclusive_scope for preloading
上级
5502780c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
13 addition
and
14 deletion
+13
-14
activerecord/lib/active_record/association_preload.rb
activerecord/lib/active_record/association_preload.rb
+13
-14
未找到文件。
activerecord/lib/active_record/association_preload.rb
浏览文件 @
8a1be228
...
...
@@ -187,13 +187,12 @@ def preload_has_and_belongs_to_many_association(records, reflection, preload_opt
conditions
=
"t0.
#{
reflection
.
primary_key_name
}
#{
in_or_equals_for_ids
(
ids
)
}
"
conditions
<<
append_conditions
(
reflection
,
preload_options
)
associated_records
=
reflection
.
klass
.
with_exclusive_scope
do
reflection
.
klass
.
where
([
conditions
,
ids
]).
associated_records
=
reflection
.
klass
.
unscoped
.
where
([
conditions
,
ids
]).
includes
(
options
[
:include
]).
joins
(
"INNER JOIN
#{
connection
.
quote_table_name
options
[
:join_table
]
}
t0 ON
#{
reflection
.
klass
.
quoted_table_name
}
.
#{
reflection
.
klass
.
primary_key
}
= t0.
#{
reflection
.
association_foreign_key
}
"
).
select
(
"
#{
options
[
:select
]
||
table_name
+
'.*'
}
, t0.
#{
reflection
.
primary_key_name
}
as the_parent_record_id"
).
order
(
options
[
:order
]).
to_a
end
set_association_collection_records
(
id_to_record_map
,
reflection
.
name
,
associated_records
,
'the_parent_record_id'
)
end
...
...
@@ -341,9 +340,7 @@ def preload_belongs_to_association(records, reflection, preload_options={})
conditions
=
"
#{
table_name
}
.
#{
connection
.
quote_column_name
(
primary_key
)
}
#{
in_or_equals_for_ids
(
ids
)
}
"
conditions
<<
append_conditions
(
reflection
,
preload_options
)
associated_records
=
klass
.
with_exclusive_scope
do
klass
.
where
([
conditions
,
ids
]).
apply_finder_options
(
options
.
slice
(
:include
,
:select
,
:joins
,
:order
)).
to_a
end
associated_records
=
klass
.
unscoped
.
where
([
conditions
,
ids
]).
apply_finder_options
(
options
.
slice
(
:include
,
:select
,
:joins
,
:order
)).
to_a
set_association_single_records
(
id_map
,
reflection
.
name
,
associated_records
,
primary_key
)
end
...
...
@@ -362,14 +359,16 @@ def find_associated_records(ids, reflection, preload_options)
conditions
<<
append_conditions
(
reflection
,
preload_options
)
reflection
.
klass
.
with_exclusive_scope
do
reflection
.
klass
.
select
(
preload_options
[
:select
]
||
options
[
:select
]
||
"
#{
table_name
}
.*"
).
includes
(
preload_options
[
:include
]
||
options
[
:include
]).
where
([
conditions
,
ids
]).
joins
(
options
[
:joins
]).
group
(
preload_options
[
:group
]
||
options
[
:group
]).
order
(
preload_options
[
:order
]
||
options
[
:order
])
end
find_options
=
{
:select
=>
preload_options
[
:select
]
||
options
[
:select
]
||
"
#{
table_name
}
.*"
,
:include
=>
preload_options
[
:include
]
||
options
[
:include
],
:conditions
=>
[
conditions
,
ids
],
:joins
=>
options
[
:joins
],
:group
=>
preload_options
[
:group
]
||
options
[
:group
],
:order
=>
preload_options
[
:order
]
||
options
[
:order
]
}
reflection
.
klass
.
unscoped
.
apply_finder_options
(
find_options
).
to_a
end
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录