活动记录(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