活动记录(mysql db)文本字段中的字符数是否有限制
这是我的模式:活动记录(mysql db)文本字段中的字符数是否有限制,mysql,ruby-on-rails,activerecord,text,Mysql,Ruby On Rails,Activerecord,Text,这是我的模式: 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 "loc
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、TEXT、MEDIUMTEXT和LONGTEXT) 每种类型的限制是
> TINYTEXT 256 bytes TEXT 65,535 bytes MEDIUMTEXT 16,777,215 bytes
> LONGTEXT 4,294,967,295 bytes
你可以相应地改变。
注意:字节大小是字符数,据我所知,Ruby本身对字符串的长度没有任何限制,因此存储在Rails中的字符串受数据库功能的限制。在我的消息模型中,我遇到了类似的问题。最初在创建模型时,消息体被定义为字符串
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