簡體   English   中英

Active Record錯誤創建數據庫

[英]Active Record error to create database

在我的spec / rails_helper.rb中 ,如果沒有退出,我有下面的代碼可以創建測試數據庫。

def database_exists?
  ActiveRecord::Base.connection rescue ActiveRecord::NoDatabaseError ? false : true
end
unless database_exists?
  ActiveRecord::Base.establish_connection(:"#{ENV['RAILS_ENV']}")
  db_config = ActiveRecord::Base.configurations[ENV['RAILS_ENV']]
  ActiveRecord::Base.connection.create_database db_config
end

但是當調用rspec時出現此錯誤:

.rbenv / versions / 2.2.1 / lib / ruby​​ / gems / 2.2.0 / gems / activerecord-4.2.1 / lib / active_record / connection_adapters / mysql2_adapter.rb:23:在mysql2_connection中的救援中:未知數據庫my -db-test'(ActiveRecord :: NoDatabaseError)

問題出在哪兒?

如果我使用system('rake db:create') ,它可以工作,但是是一個很好的實踐嗎?

該數據庫不存在,因此為了避免錯誤可以運行:

rake db:create

或者您可以運行:

rake db:setup

這將創建數據庫並運行遷移文件。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM