这是我的架构:
create_table "delayed_jobs", :force => true do |t|
t.integer "priority", :default => 0
t.integer "attempts", :default => 0
t.text "handler"
t.text "last_error"
t.datetime "run_at"
t.datetime "locked_at"
t.datetime "failed_at"
t.string "locked_by"
t.string "queue"
t.datetime "created_at"
t.datetime "updated_at"
end
我正在使用延迟的电子邮件工作。我的一封电子邮件中有一个非常长的处理程序(50000+)字符,当它保存在处理程序文本字段中时会发生这种情况。文本字段通常可以使用多少个字符,我应该如何增加它?
答案 0 :(得分:6)
MySQL支持4种TEXT字段类型
(TINYTEXT,TEXT,MEDIUMTEXT和LONGTEXT)
每种类型的限制是
> TINYTEXT 256 bytes TEXT 65,535 bytes MEDIUMTEXT 16,777,215 bytes
> LONGTEXT 4,294,967,295 bytes
您可以相应更改。 注意:大小(以字节为单位)是字符数
答案 1 :(得分:2)
我的消息模型中遇到了类似的问题。最初在创建模型时,消息体被定义为字符串
create_table :messages do |t|
t.string :body,
......
end
这会将我的邮件正文截断为256个字符。所以我用另一个迁移更改了该列:
def up
change_table :messages do |t|
t.change :body, :text
end
end
正如mhasan在他的回答中所概述的那样:文本长度为65535字节。如果您需要更长时间,可以使用:mediumtext或:longtext代替
答案 2 :(得分:1)
据我所知,Ruby本身对字符串的长度没有任何限制,因此存储在Rails中的字符串受数据库功能的限制。