Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
e0b76d61
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,体验更适合开发者的 AI 搜索 >>
提交
e0b76d61
编写于
10月 10, 2010
作者:
S
Santiago Pastorino
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
reorder removed in favor of except(:order).order
上级
21a92b8d
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
5 addition
and
36 deletion
+5
-36
activerecord/lib/active_record/base.rb
activerecord/lib/active_record/base.rb
+1
-1
activerecord/lib/active_record/relation/query_methods.rb
activerecord/lib/active_record/relation/query_methods.rb
+1
-10
activerecord/lib/active_record/relation/spawn_methods.rb
activerecord/lib/active_record/relation/spawn_methods.rb
+1
-10
activerecord/test/cases/relation_scoping_test.rb
activerecord/test/cases/relation_scoping_test.rb
+2
-8
activerecord/test/cases/relations_test.rb
activerecord/test/cases/relations_test.rb
+0
-6
activerecord/test/models/developer.rb
activerecord/test/models/developer.rb
+0
-1
未找到文件。
activerecord/lib/active_record/base.rb
浏览文件 @
e0b76d61
...
...
@@ -423,7 +423,7 @@ class Base
class
<<
self
# Class methods
delegate
:find
,
:first
,
:last
,
:all
,
:destroy
,
:destroy_all
,
:exists?
,
:delete
,
:delete_all
,
:update
,
:update_all
,
:to
=>
:scoped
delegate
:find_each
,
:find_in_batches
,
:to
=>
:scoped
delegate
:select
,
:group
,
:order
,
:
reorder
,
:limit
,
:offset
,
:joins
,
:where
,
:preload
,
:eager_load
,
:includes
,
:from
,
:lock
,
:readonly
,
:having
,
:create_with
,
:to
=>
:scoped
delegate
:select
,
:group
,
:order
,
:
except
,
:limit
,
:offset
,
:joins
,
:where
,
:preload
,
:eager_load
,
:includes
,
:from
,
:lock
,
:readonly
,
:having
,
:create_with
,
:to
=>
:scoped
delegate
:count
,
:average
,
:minimum
,
:maximum
,
:sum
,
:calculate
,
:to
=>
:scoped
# Executes a custom SQL query against your database and returns all the results. The results will
...
...
activerecord/lib/active_record/relation/query_methods.rb
浏览文件 @
e0b76d61
...
...
@@ -6,7 +6,7 @@ module QueryMethods
extend
ActiveSupport
::
Concern
attr_accessor
:includes_values
,
:eager_load_values
,
:preload_values
,
:select_values
,
:group_values
,
:order_values
,
:
reorder_flag
,
:
joins_values
,
:where_values
,
:having_values
,
:select_values
,
:group_values
,
:order_values
,
:joins_values
,
:where_values
,
:having_values
,
:limit_value
,
:offset_value
,
:lock_value
,
:readonly_value
,
:create_with_value
,
:from_value
def
includes
(
*
args
)
...
...
@@ -53,15 +53,6 @@ def order(*args)
relation
end
def
reorder
(
*
args
)
relation
=
clone
unless
args
.
blank?
relation
.
order_values
=
args
relation
.
reorder_flag
=
true
end
relation
end
def
joins
(
*
args
)
relation
=
clone
...
...
activerecord/lib/active_record/relation/spawn_methods.rb
浏览文件 @
e0b76d61
...
...
@@ -19,20 +19,11 @@ def merge(r)
end
end
(
Relation
::
MULTI_VALUE_METHODS
-
[
:joins
,
:where
,
:order
]).
each
do
|
method
|
(
Relation
::
MULTI_VALUE_METHODS
-
[
:joins
,
:where
]).
each
do
|
method
|
value
=
r
.
send
(
:"
#{
method
}
_values"
)
merged_relation
.
send
(
:"
#{
method
}
_values="
,
merged_relation
.
send
(
:"
#{
method
}
_values"
)
+
value
)
if
value
.
present?
end
order_value
=
r
.
order_values
if
order_value
.
present?
if
r
.
reorder_flag
merged_relation
.
order_values
=
order_value
else
merged_relation
.
order_values
=
merged_relation
.
order_values
+
order_value
end
end
merged_relation
=
merged_relation
.
joins
(
r
.
joins_values
)
merged_wheres
=
@where_values
...
...
activerecord/test/cases/relation_scoping_test.rb
浏览文件 @
e0b76d61
...
...
@@ -384,18 +384,12 @@ def test_named_scope_overwrites_default
assert_equal
expected
,
received
end
def
test_
re
order_overrides_default_scope_order
def
test_
except_and_
order_overrides_default_scope_order
expected
=
Developer
.
order
(
'name DESC'
).
collect
{
|
dev
|
dev
.
name
}
received
=
DeveloperOrderedBySalary
.
re
order
(
'name DESC'
).
collect
{
|
dev
|
dev
.
name
}
received
=
DeveloperOrderedBySalary
.
except
(
:order
).
order
(
'name DESC'
).
collect
{
|
dev
|
dev
.
name
}
assert_equal
expected
,
received
end
def
test_reordered_scope_overrides_default_scope_order
not_expected
=
DeveloperOrderedBySalary
.
first
# Jamis -> name DESC
received
=
DeveloperOrderedBySalary
.
reordered_by_name
.
first
# David -> name
assert
not_expected
.
id
!=
received
.
id
end
def
test_nested_exclusive_scope
expected
=
Developer
.
find
(
:all
,
:limit
=>
100
).
collect
{
|
dev
|
dev
.
salary
}
received
=
DeveloperOrderedBySalary
.
send
(
:with_exclusive_scope
,
:find
=>
{
:limit
=>
100
})
do
...
...
activerecord/test/cases/relations_test.rb
浏览文件 @
e0b76d61
...
...
@@ -135,12 +135,6 @@ def test_finding_with_order_concatenated
assert_equal
topics
(
:fourth
).
title
,
topics
.
first
.
title
end
def
test_finding_with_reorder
topics
=
Topic
.
order
(
'author_name'
).
order
(
'title'
).
reorder
(
'id'
)
assert_equal
4
,
topics
.
to_a
.
size
assert_equal
topics
(
:first
).
title
,
topics
.
first
.
title
end
def
test_finding_with_order_and_take
entrants
=
Entrant
.
order
(
"id ASC"
).
limit
(
2
).
to_a
...
...
activerecord/test/models/developer.rb
浏览文件 @
e0b76d61
...
...
@@ -88,7 +88,6 @@ class DeveloperOrderedBySalary < ActiveRecord::Base
self
.
table_name
=
'developers'
default_scope
:order
=>
'salary DESC'
scope
:by_name
,
order
(
'name DESC'
)
scope
:reordered_by_name
,
reorder
(
'name'
)
def
self
.
all_ordered_by_name
with_scope
(
:find
=>
{
:order
=>
'name DESC'
})
do
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录