Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
482091ca
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,发现更多精彩内容 >>
提交
482091ca
编写于
5月 23, 2014
作者:
R
Rafael Mendonça França
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #15277 from sgrif/sg-schema-cache-refactor
Simplify the code in schema cache
上级
a6f55fe2
2004e4ef
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
31 deletion
+11
-31
activerecord/lib/active_record/connection_adapters/schema_cache.rb
...ord/lib/active_record/connection_adapters/schema_cache.rb
+11
-31
未找到文件。
activerecord/lib/active_record/connection_adapters/schema_cache.rb
浏览文件 @
482091ca
...
...
@@ -12,11 +12,10 @@ def initialize(conn)
@columns_hash
=
{}
@primary_keys
=
{}
@tables
=
{}
prepare_default_proc
end
def
primary_keys
(
table_name
)
@primary_keys
[
table_name
]
@primary_keys
[
table_name
]
||=
table_exists?
(
table_name
)
?
connection
.
primary_key
(
table_name
)
:
nil
end
# A cached lookup for table existence.
...
...
@@ -29,9 +28,9 @@ def table_exists?(name)
# Add internal cache for table with +table_name+.
def
add
(
table_name
)
if
table_exists?
(
table_name
)
@primary_keys
[
table_name
]
@columns
[
table_name
]
@columns_hash
[
table_name
]
primary_keys
(
table_name
)
columns
(
table_name
)
columns_hash
(
table_name
)
end
end
...
...
@@ -40,14 +39,16 @@ def tables(name)
end
# Get the columns for a table
def
columns
(
table
)
@columns
[
table
]
def
columns
(
table
_name
)
@columns
[
table
_name
]
||=
connection
.
columns
(
table_name
)
end
# Get the columns for a table as a hash, key is the column name
# value is the column object.
def
columns_hash
(
table
)
@columns_hash
[
table
]
def
columns_hash
(
table_name
)
@columns_hash
[
table_name
]
||=
Hash
[
columns
(
table_name
).
map
{
|
col
|
[
col
.
name
,
col
]
}]
end
# Clears out internal caches
...
...
@@ -76,32 +77,11 @@ def clear_table_cache!(table_name)
def
marshal_dump
# if we get current version during initialization, it happens stack over flow.
@version
=
ActiveRecord
::
Migrator
.
current_version
[
@version
]
+
[
@columns
,
@columns_hash
,
@primary_keys
,
@tables
].
map
{
|
val
|
Hash
[
val
]
}
[
@version
,
@columns
,
@columns_hash
,
@primary_keys
,
@tables
]
end
def
marshal_load
(
array
)
@version
,
@columns
,
@columns_hash
,
@primary_keys
,
@tables
=
array
prepare_default_proc
end
private
def
prepare_default_proc
@columns
.
default_proc
=
Proc
.
new
do
|
h
,
table_name
|
h
[
table_name
]
=
connection
.
columns
(
table_name
)
end
@columns_hash
.
default_proc
=
Proc
.
new
do
|
h
,
table_name
|
h
[
table_name
]
=
Hash
[
columns
(
table_name
).
map
{
|
col
|
[
col
.
name
,
col
]
}]
end
@primary_keys
.
default_proc
=
Proc
.
new
do
|
h
,
table_name
|
h
[
table_name
]
=
table_exists?
(
table_name
)
?
connection
.
primary_key
(
table_name
)
:
nil
end
end
end
end
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录