Mysql2 ::错误:表'table_name'不存在:显示来自`table_name`的完整字段

时间:2017-06-22 14:01:27

标签: mysql ruby-on-rails ruby-on-rails-5.1

在提交问题之前,我已尝试使用每个stackoverflow.com类似的参数。但我没有发现问题。 我正在使用rails 5.1.1和mysql 5.7 我有这个名为的迁移类:

    class CreateCompanies < ActiveRecord::Migration[5.1]
  def change
    create_table :companies do |t|
    t.string :ragione_sociale
    t.references :forma_giuridica, foreign_key: true
    t.string :telefono_fisso
    t.string :fax
    t.string :pec
    t.string :mail
    t.string :web_site
    t.string :cellulare_emergenze
    t.string :via_legale
    t.string :n_civico_legale
    t.string :citta_legale
    t.string :cap_legale
    t.string :provincia_legale
    t.string :regione_legale
    t.string :via_operativa
    t.string :n_civico_operativa
    t.string :citta_operativa
    t.string :cap_operativa
    t.string :provincia_operativa
    t.string :regione_operativa
    t.string :pi
    t.string :cf
    t.string :ateco_primo
    t.string :ateco_secondo
    t.string :ateco_altro
    t.timestamps
    end
  end
end

我有一个空模型calledny.rb和一个名为companies_controller.rb的控制器。

我的database.yml是:

# MySQL. Versions 5.1.10 and up are supported.
#
# Install the MySQL driver
#   gem install mysql2
#
# Ensure the MySQL gem is defined in your Gemfile
#   gem 'mysql2'
#
# And be sure to use new-style password hashing:
#   http://dev.mysql.com/doc/refman/5.7/en/old-client.html
#
default: &default
  adapter: mysql2
  encoding: utf8
  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
  username: root
  password: Pipipopo09
  host: localhost
  port: 3300

development:
  <<: *default
  database: Pluto_Demetra_development

# Warning: The database defined as "test" will be erased and
# re-generated from your development database when you run "rake".
# Do not set this db to the same as development or production.
test:
  <<: *default
  database: Pluto_Demetra_test

# As with config/secrets.yml, you never want to store sensitive information,
# like your database password, in your source code. If your source code is
# ever seen by anyone, they now have access to your database.
#
# Instead, provide the password as a unix environment variable when you boot
# the app. Read http://guides.rubyonrails.org/configuring.html#configuring-a-database
# for a full rundown on how to provide these environment variables in a
# production deployment.
#
# On Heroku and other platform providers, you may have a full connection URL
# available as an environment variable. For example:
#
#   DATABASE_URL="mysql2://myuser:mypass@localhost/somedatabase"
#
# You can use this database configuration with:
#
#   production:
#     url: <%= ENV['DATABASE_URL'] %>
#
production:
  <<: *default
  database: Pluto_Demetra_production
  username: Pluto_Demetra
  password: <%= ENV['PLUTO_DEMETRA_DATABASE_PASSWORD'] %>

运行rails db:migrate时出现以下错误:

== 20170621125622 CreateCompanies: migrating ==================================
-- create_table(:companies)
rails aborted!
StandardError: An error has occurred, all later migrations canceled:

Mysql2::Error: Table 'pluto_demetra_development.companies' doesn't exist: SHOW FULL FIELDS FROM `companies`
C:/Users/gvieri.BSNSTRATEGIES/SitiRuby/Pluto_Demetra/db/migrate/20170621125622_create_companies.rb:3:in `change'
bin/rails:4:in `require'
bin/rails:4:in `<main>'
ActiveRecord::StatementInvalid: Mysql2::Error: Table 'pluto_demetra_development.companies' doesn't exist: SHOW FULL FIELDS FROM `companies`
C:/Users/gvieri.BSNSTRATEGIES/SitiRuby/Pluto_Demetra/db/migrate/20170621125622_create_companies.rb:3:in `change'
bin/rails:4:in `require'
bin/rails:4:in `<main>'
Mysql2::Error: Table 'pluto_demetra_development.companies' doesn't exist
C:/Users/gvieri.BSNSTRATEGIES/SitiRuby/Pluto_Demetra/db/migrate/20170621125622_create_companies.rb:3:in `change'
bin/rails:4:in `require'
bin/rails:4:in `<main>'
Mysql2::Error: Cannot add foreign key constraint
C:/Users/gvieri.BSNSTRATEGIES/SitiRuby/Pluto_Demetra/db/migrate/20170621125622_create_companies.rb:3:in `change'
bin/rails:4:in `require'
bin/rails:4:in `<main>'
Tasks: TOP => db:migrate
(See full trace by running task with --trace)

我可以帮助我。提前谢谢。

3 个答案:

答案 0 :(得分:10)

可能是由ActiveRecord :: Migration [5.1]引起的。如果要将外键添加到companies表,则迁移首先读取表,但它不存在。

将迁移更改为5.0适用于我。

class CreateCompanies < ActiveRecord::Migration[5.0]
end

或者首先删除外部选项,然后手动添加外键:

class CreateCompanies < ActiveRecord::Migration[5.1]
  def change
    create_table :companies do |t|
      t.string :ragione_sociale
      t.references :forma_giuridica # without :foreign_key option
      # ...
    end

    # add foreign key here
    add_reference :companies, :forma_giuridica
  end
end

答案 1 :(得分:3)

:: Migration [5.0]使用主键int(11)

:: Migration [5.1]使用主键bigint(20)

最常见的原因是,在创建外键时,引用字段和外键字段都需要匹配:

  • 引擎应该是相同的,例如。 InnoDB
  • 数据类型应该相同,长度相同 e.g。 VARCHAR(20)或INT(10)UNSIGNED
  • 整理应该相同。 e.g。 utf8
  • 唯一 - 外键应引用参考表中唯一(通常为私有)的字段。

答案 2 :(得分:0)

如其他答案所述,当您使用的ActiveRecord :: Migration版本对目标MySQL表上的id字段的类型做出错误假设时,会出现此错误。

特别是从5.1版开始,ActiveRecord假定id字段的类型为bigint,而不是以前版本中的int类型。

您可以通过在迁移过程中手动指定外键的目标字段为type: :int来解决此问题,如下所示:

class MyMigration < ActiveRecord::Migration[5.2]
  def change
    create_table :my_new_table do |t|
      t.references :my_existing_table,
                   foreign_key: true,
                   type: :int
    end
  end
end