corrivate / laravel-mysqldump
Artisan commands to conveniently dump and import the DB, with stripping options
Installs: 283
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/corrivate/laravel-mysqldump
Requires
- php: ^8.0
- spatie/db-dumper: ^3.8
README
Purpose
- Easily dump whole databases or specific tables, with
artisan mysql:export - Easily import, with
artisan mysql:import - Strip content from tables, for example, strip the customer data but keep the product catalog.
IMPORTANT Stripping content from tables does not respect foreign key constraints. Meaning, if you strip a parent table but NOT a child table that depends on the parent, and then import that file somewhere else, you're going to foreign key failures. Always make sure to also strip dependent tables.
Setup
Install with:
composer require corrivate/laravel-mysqldump
Configuration
Configuration is not required. You can ad-hoc decide to strip tables by using artisan mysql:export --strip= with a comma-separated list of tables.
If your project has a standard set of tables you usually want to strip during export, you can add those to your config/database.php to be stripped by default.
'mysql' => [ 'driver' => 'mysql', 'url' => env('DB_URL'), 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => env('DB_DATABASE', 'laravel'), 'username' => env('DB_USERNAME', 'root'), 'password' => env('DB_PASSWORD', ''), 'unix_socket' => env('DB_SOCKET', ''), 'charset' => env('DB_CHARSET', 'utf8mb4'), 'collation' => env('DB_COLLATION', 'utf8mb4_unicode_ci'), 'prefix' => '', 'prefix_indexes' => true, 'strict' => true, 'engine' => null, 'options' => extension_loaded('pdo_mysql') ? array_filter([ PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'), ]) : [], // These tables will only have their schema exported, no data 'strip_tables_on_export' => [ 'cache', 'cache_locks', 'job_batches', 'jobs', 'users', 'password_reset_tokens', 'sessions', 'pulse_aggregates', 'pulse_entries', 'pulse_values', ], ],
This configuration will be applied by default when using a stripped mode export. If you want to run a stripped export without this configuration, pass a --config-stripped=0 option to the command.
Note that you can combine or replace this with the --strip-manual=your,specific,tables option.
Usage
Export
artisan mysql:export [options]
The default behavior is to create a gzipped file dump.sql.gz with an export based on your stripping configuration.
Options
--filename=dump.sql: Name of the file to export to. Note that '.gz' will be appended if using the gzip option as well.--gzip=1can be set to 0 to turn off compression.--mode=stripped: perform astripped,schemaorfullexport. Default is stripped.--config-stripped=1adds the tables configured indatabase.mysql.strip_tables_on_exportto the list of tables to strip. Default is 1; set to 0 if you only want to manually strip tables.--strip-manual=(OPTIONAL) accepts a comma-separated list of tables to strip. These will me merged with those from your configuration (if any).
Import
artisan mysql:import <filename>
Credits
This package is built on top of spatie/db-dumper. The original inspiration was the Magento packages magerun2 and mage-db-sync.
Corrivate
(en.wiktionary.org)
Etymology
From Latin corrivatus, past participle of corrivare ("to corrivate").
Verb
corrivate (third-person singular simple present corrivates, present participle corrivating, simple past and past participle corrivated)
(obsolete) To cause to flow together, as water drawn from several streams.
