sql >> Databasteknik >  >> RDS >> Mysql

Importera Mysql-databas med Ruby/Chef Recept for Vagrant

Om det är ett filsökvägsfel och du använder chef solo, försök använda sökvägen som anges i solo.rb , som:

/tmp/chef-solo/site-cookbooks/path_to_file.sql

Som en allmän not, överväg att använda databaskokboken för mysql användar- och databashanteringsuppgifter. När du har ställt in de nödvändiga kokboksberoendena kan du lägga in kod som denna i ditt huvudrecepts default.rb :

# externalize conection info in a ruby hash
mysql_connection_info = {
  :host => "localhost",
  :username => 'root',
  :password => node['mysql']['server_root_password']
}

# drop if exists, then create a mysql database named DB_NAME
mysql_database 'DB_NAME' do
  connection mysql_connection_info
  action [:drop, :create]
end

# query a database from a sql script on disk
mysql_database "DB_NAME" do
  connection mysql_connection_info
  sql { ::File.open("/tmp/chef-solo/site-cookbooks/main/path/to/sql_script.sql").read }
  action :query
end

#or import from a dump file
mysql_database "DB_NAME" do
  connection mysql_connection_info
  sql "source /tmp/chef-solo/site-cookbooks/main/path/to/sql_dump.sql;"
end

Har inte testat den sista eftersom lagring av en databasfil i kockkatalogen verkligen saktar ner saker och ting.

Se även:Importera SQL-fil till mysql



  1. Återställ en SQL Server-databas (T-SQL)

  2. Kapslad select-sats i SQL Server

  3. Fel i MySQL vid inställning av standardvärde för DATE eller DATETIME

  4. Hur konverterar jag ett intervall till ett antal timmar med postgres?