通过ruby Rails迁移添加MySQL枚举列时出现问题

时间:2019-05-08 14:03:35

标签: mysql ruby-on-rails ruby enums rails-migrations

我正在尝试通过以下方式添加MySQL枚举列:

# frozen_string_literal: true
class AddStatusToTasks < ActiveRecord::Migration[6.0]
  def up
    execute <<-SQL
        ALTER TABLE tasks ADD status enum('to_do', 'doing', 'done');
    SQL
  end
  def down
    remove_column :tasks, :status
  end
end

但是我得到了错误:

AddStatusToTasks: migrating =================================
-- execute("        ALTER TABLE tasks ADD status enum('to_do', 'doing', 'done');\n")
rails aborted!
StandardError: An error has occurred, this and all later migrations canceled:

SQLite3::SQLException: near "'to_do'": syntax error

我的模特喜欢的样子:

class Task < ApplicationRecord
  belongs_to :user
  enum status: { to_do: 'to_do', doing: 'doing', done: 'done' }
end

我实际上正在遵循指南here,但我找不到问题。

提前感谢大家的帮助!

1 个答案:

答案 0 :(得分:0)

SQLite3::SQLException-您正在SQLite数据库而不是MySQL上执行此查询。您使用的环境是否正确?