这是我的模式:
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+)字符,这恰好在保存在处理程序文本字段中时被切断。文本字段通常可以采用多少个字符,我应该如何增加它?
MySQL支持4种文本字段类型
(小文本、文本、中等文本和长文本)
每种类型的限制为
> TINYTEXT 256 bytes TEXT 65,535 bytes MEDIUMTEXT 16,777,215 bytes
> LONGTEXT 4,294,967,295 bytes
您可以相应地更改。注意:以字节为单位的大小是字符数
在我的消息模型中,我遇到了与此类似的问题。最初在创建模型时,消息正文定义为字符串
create_table :messages do |t|
t.string :body,
......
end
这会将我的邮件正文截断为 256 个字符。所以我用另一个迁移更改了该列:
def up
change_table :messages do |t|
t.change :body, :text
end
end
正如 mhasan 在他的回答中概述的那样,:text 的长度为 65535 字节。如果你需要更长的时间,你可以使用 :mediumtext 或 :longtext 来代替
据我所知,Ruby本身对字符串的长度没有任何限制,因此存储在Rails中的字符串受到数据库功能的限制。