3

这是我的架构:

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+)个字符,当它保存在处理程序文本字段中时,这恰好被切断了。一个文本字段通常可以占用多少个字符,我应该如何增加它?

4

3 回答 3

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

您可以进行相应的更改。注意:以字节为单位的大小是字符数

于 2012-09-24T06:22:24.700 回答
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 在他的回答中概述的那样, :text 的长度为 65535 个字节。如果您需要更长的时间,可以使用 :mediumtext 或 :longtext 代替

于 2012-09-24T10:38:52.507 回答
1

据我所知,Ruby 本身对字符串的长度没有任何限制,因此存储在 Rails 中的字符串受到数据库功能的限制。

于 2012-09-24T08:36:04.203 回答