我有一个类似于下面的Rake脚本,但我想知道是否有更有效的方法来执行此操作,而不必删除数据库,运行所有迁移,重新设置数据库,然后添加示例数据?
namespace :db do desc 'Fill database with sample data' task populate: :environment do purge_database create_researchers create_organisations add_survey_groups_to_organisations add_members_to_survey_groups create_survey_responses_for_members end end def purge_database puts 'about to drop and recreate database' system('rake db:drop') puts 'database dropped' system('rake db:create') system('rake db:migrate') system('rake db:seed') puts 'Database recreated...' end def create_researchers 10.times do researcher = User.new researcher.email = Faker::Internet.email researcher.save! end end
解决方法
我建议让rake db:seed自给自足.我的意思是,你应该能够多次运行它而不会造成任何损害,同时确保加载所需的任何样本数据.
因此,对于您的研究,db:seed任务应该执行以下操作:
User.destroy_all 10.times do researcher = User.new researcher.email = Faker::Internet.email researcher.save! end
我认为这是为了发展.在这种情况下,我不会把它放在db:seed中,因为它可能会在生产中运行.但是你可以把它放在一个类似的rake任务中,你可以根据需要重新运行.