Class: ActiveRecord::Tasks::MySQLDatabaseTasks
- Inherits:
-
Object
- Object
- ActiveRecord::Tasks::MySQLDatabaseTasks
- Defined in:
- lib/active_record/tasks/mysql_database_tasks.rb
Overview
:nodoc:
Constant Summary collapse
- DEFAULT_CHARSET =
ENV['CHARSET'] || 'utf8'
- DEFAULT_COLLATION =
ENV['COLLATION'] || 'utf8_unicode_ci'
- ACCESS_DENIED_ERROR =
1045
Instance Method Summary collapse
- #charset ⇒ Object
- #collation ⇒ Object
- #create ⇒ Object
- #drop ⇒ Object
-
#initialize(configuration) ⇒ MySQLDatabaseTasks
constructor
A new instance of MySQLDatabaseTasks.
- #purge ⇒ Object
- #structure_dump(filename) ⇒ Object
- #structure_load(filename) ⇒ Object
Constructor Details
#initialize(configuration) ⇒ MySQLDatabaseTasks
Returns a new instance of MySQLDatabaseTasks.
10 11 12 |
# File 'lib/active_record/tasks/mysql_database_tasks.rb', line 10 def initialize(configuration) @configuration = configuration end |
Instance Method Details
#charset ⇒ Object
49 50 51 |
# File 'lib/active_record/tasks/mysql_database_tasks.rb', line 49 def charset connection.charset end |
#collation ⇒ Object
53 54 55 |
# File 'lib/active_record/tasks/mysql_database_tasks.rb', line 53 def collation connection.collation end |
#create ⇒ Object
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'lib/active_record/tasks/mysql_database_tasks.rb', line 14 def create establish_connection configuration_without_database connection.create_database configuration['database'], establish_connection configuration rescue ActiveRecord::StatementInvalid => error if /database exists/ === error. raise DatabaseAlreadyExists else raise end rescue error_class => error if error.respond_to?(:errno) && error.errno == ACCESS_DENIED_ERROR $stdout.print error.error establish_connection root_configuration_without_database connection.create_database configuration['database'], if configuration['username'] != 'root' connection.execute grant_statement.gsub(/\s+/, ' ').strip end establish_connection configuration else $stderr.puts "Couldn't create database for #{configuration.inspect}, #{.inspect}" $stderr.puts "(If you set the charset manually, make sure you have a matching collation)" if configuration['encoding'] end end |
#drop ⇒ Object
39 40 41 42 |
# File 'lib/active_record/tasks/mysql_database_tasks.rb', line 39 def drop establish_connection configuration connection.drop_database configuration['database'] end |
#purge ⇒ Object
44 45 46 47 |
# File 'lib/active_record/tasks/mysql_database_tasks.rb', line 44 def purge establish_connection :test connection.recreate_database configuration['database'], end |
#structure_dump(filename) ⇒ Object
57 58 59 60 61 62 63 64 65 66 |
# File 'lib/active_record/tasks/mysql_database_tasks.rb', line 57 def structure_dump(filename) args = ('mysqldump') args.concat(["--result-file", "#{filename}"]) args.concat(["--no-data"]) args.concat(["#{configuration['database']}"]) unless Kernel.system(*args) $stderr.puts "Could not dump the database structure. "\ "Make sure `mysqldump` is in your PATH and check the command output for warnings." end end |
#structure_load(filename) ⇒ Object
68 69 70 71 72 73 |
# File 'lib/active_record/tasks/mysql_database_tasks.rb', line 68 def structure_load(filename) args = ('mysql') args.concat(['--execute', %{SET FOREIGN_KEY_CHECKS = 0; SOURCE #{filename}; SET FOREIGN_KEY_CHECKS = 1}]) args.concat(["--database", "#{configuration['database']}"]) Kernel.system(*args) end |