活动记录(mysql db)文本字段中的字符数是否有限制

时间:2012-09-24 06:15:36

标签: 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 "locked_at"
    t.datetime "failed_at"
    t.string   "locked_by"
    t.string   "queue"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

我正在使用延迟的电子邮件工作。我的一封电子邮件中有一个非常长的处理程序(50000+)字符,当它保存在处理程序文本字段中时会发生这种情况。文本字段通常可以使用多少个字符,我应该如何增加它?

3 个答案:

答案 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中的字符串受数据库功能的限制。