Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
f1dc5e6b
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 搜索 >>
未验证
提交
f1dc5e6b
编写于
5月 15, 2020
作者:
R
Ryuta Kamizono
提交者:
GitHub
5月 15, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #39284 from kamipo/support_native_rename_column
Support native RENAME COLUMN syntax for MySQL
上级
459db0a6
682274f1
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
20 addition
and
2 deletion
+20
-2
activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb
..._record/connection_adapters/abstract/schema_statements.rb
+4
-0
activerecord/lib/active_record/connection_adapters/abstract_mysql_adapter.rb
...tive_record/connection_adapters/abstract_mysql_adapter.rb
+10
-0
activerecord/lib/active_record/connection_adapters/postgresql/schema_statements.rb
...ecord/connection_adapters/postgresql/schema_statements.rb
+1
-1
activerecord/test/cases/adapters/mysql2/connection_test.rb
activerecord/test/cases/adapters/mysql2/connection_test.rb
+5
-1
未找到文件。
activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb
浏览文件 @
f1dc5e6b
...
...
@@ -1493,6 +1493,10 @@ def add_column_for_alter(table_name, column_name, type, **options)
schema_creation
.
accept
(
AddColumnDefinition
.
new
(
cd
))
end
def
rename_column_for_alter
(
table_name
,
column_name
,
new_column_name
)
"RENAME COLUMN
#{
quote_column_name
(
column_name
)
}
TO
#{
quote_column_name
(
new_column_name
)
}
"
end
def
remove_column_for_alter
(
table_name
,
column_name
,
type
=
nil
,
**
options
)
"DROP COLUMN
#{
quote_column_name
(
column_name
)
}
"
end
...
...
activerecord/lib/active_record/connection_adapters/abstract_mysql_adapter.rb
浏览文件 @
f1dc5e6b
...
...
@@ -667,6 +667,8 @@ def change_column_for_alter(table_name, column_name, type, options = {})
end
def
rename_column_for_alter
(
table_name
,
column_name
,
new_column_name
)
return
super
if
supports_rename_column?
column
=
column_for
(
table_name
,
column_name
)
options
=
{
default:
column
.
default
,
...
...
@@ -701,6 +703,14 @@ def supports_rename_index?
end
end
def
supports_rename_column?
if
mariadb?
database_version
>=
"10.5.2"
else
database_version
>=
"8.0.3"
end
end
def
configure_connection
variables
=
@config
.
fetch
(
:variables
,
{}).
stringify_keys
...
...
activerecord/lib/active_record/connection_adapters/postgresql/schema_statements.rb
浏览文件 @
f1dc5e6b
...
...
@@ -437,7 +437,7 @@ def change_table_comment(table_name, comment_or_changes) # :nodoc:
# Renames a column in a table.
def
rename_column
(
table_name
,
column_name
,
new_column_name
)
#:nodoc:
clear_cache!
execute
"ALTER TABLE
#{
quote_table_name
(
table_name
)
}
RENAME COLUMN
#{
quote_column_name
(
column_name
)
}
TO
#{
quote_column_name
(
new_column_name
)
}
"
execute
(
"ALTER TABLE
#{
quote_table_name
(
table_name
)
}
#{
rename_column_for_alter
(
table_name
,
column_name
,
new_column_name
)
}
"
)
rename_column_indexes
(
table_name
,
column_name
,
new_column_name
)
end
...
...
activerecord/test/cases/adapters/mysql2/connection_test.rb
浏览文件 @
f1dc5e6b
...
...
@@ -170,7 +170,11 @@ def test_logs_name_rename_column_for_alter
@connection
.
execute
"CREATE TABLE `bar_baz` (`foo` varchar(255))"
@subscriber
.
logged
.
clear
@connection
.
send
(
:rename_column_for_alter
,
"bar_baz"
,
"foo"
,
"foo2"
)
assert_equal
"SCHEMA"
,
@subscriber
.
logged
[
0
][
1
]
if
@connection
.
send
(
:supports_rename_column?
)
assert_empty
@subscriber
.
logged
else
assert_equal
"SCHEMA"
,
@subscriber
.
logged
[
0
][
1
]
end
ensure
@connection
.
execute
"DROP TABLE `bar_baz`"
end
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录