[英]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.