Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
fe7cacb5
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 搜索 >>
提交
fe7cacb5
编写于
2月 26, 2012
作者:
K
kennyj
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix type_to_sql with text and limit on mysql/mysql2. Fix GH #3931.
上级
29054ba1
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
23 addition
and
12 deletion
+23
-12
activerecord/lib/active_record/connection_adapters/abstract_mysql_adapter.rb
...tive_record/connection_adapters/abstract_mysql_adapter.rb
+20
-9
activerecord/test/schema/mysql2_specific_schema.rb
activerecord/test/schema/mysql2_specific_schema.rb
+2
-2
activerecord/test/schema/mysql_specific_schema.rb
activerecord/test/schema/mysql_specific_schema.rb
+1
-1
未找到文件。
activerecord/lib/active_record/connection_adapters/abstract_mysql_adapter.rb
浏览文件 @
fe7cacb5
...
...
@@ -484,15 +484,26 @@ def rename_column(table_name, column_name, new_column_name) #:nodoc:
# Maps logical Rails types to MySQL-specific data types.
def
type_to_sql
(
type
,
limit
=
nil
,
precision
=
nil
,
scale
=
nil
)
return
super
unless
type
.
to_s
==
'integer'
case
limit
when
1
;
'tinyint'
when
2
;
'smallint'
when
3
;
'mediumint'
when
nil
,
4
,
11
;
'int(11)'
# compatibility with MySQL default
when
5
..
8
;
'bigint'
else
raise
(
ActiveRecordError
,
"No integer type has byte size
#{
limit
}
"
)
case
type
.
to_s
when
'integer'
case
limit
when
1
;
'tinyint'
when
2
;
'smallint'
when
3
;
'mediumint'
when
nil
,
4
,
11
;
'int(11)'
# compatibility with MySQL default
when
5
..
8
;
'bigint'
else
raise
(
ActiveRecordError
,
"No integer type has byte size
#{
limit
}
"
)
end
when
'text'
case
limit
when
0
..
0xff
;
'tinytext'
when
nil
,
0x100
..
0xffff
;
'text'
when
0x10000
..
0xffffff
;
'mediumtext'
when
0x1000000
..
0xffffffff
;
'longtext'
else
raise
(
ActiveRecordError
,
"No text type has character length
#{
limit
}
"
)
end
else
super
end
end
...
...
activerecord/test/schema/mysql2_specific_schema.rb
浏览文件 @
fe7cacb5
ActiveRecord
::
Schema
.
define
do
create_table
:binary_fields
,
:force
=>
true
,
:options
=>
'CHARACTER SET latin1'
do
|
t
|
create_table
:binary_fields
,
:force
=>
true
do
|
t
|
t
.
binary
:tiny_blob
,
:limit
=>
255
t
.
binary
:normal_blob
,
:limit
=>
65535
t
.
binary
:medium_blob
,
:limit
=>
16777215
...
...
@@ -32,4 +32,4 @@
) CHARACTER SET utf8 COLLATE utf8_general_ci
SQL
end
\ No newline at end of file
end
activerecord/test/schema/mysql_specific_schema.rb
浏览文件 @
fe7cacb5
ActiveRecord
::
Schema
.
define
do
create_table
:binary_fields
,
:force
=>
true
,
:options
=>
'CHARACTER SET latin1'
do
|
t
|
create_table
:binary_fields
,
:force
=>
true
do
|
t
|
t
.
binary
:tiny_blob
,
:limit
=>
255
t
.
binary
:normal_blob
,
:limit
=>
65535
t
.
binary
:medium_blob
,
:limit
=>
16777215
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录