jpswade / laravel-database-tools
Laravel Database Tools
Package info
github.com/jpswade/laravel-database-tools
Type:laravel-package
pkg:composer/jpswade/laravel-database-tools
Requires
- php: ^8.1|^8.2|^8.3|^8.4|^8.5
- ext-fileinfo: *
- ext-pdo: *
- ext-zip: *
- illuminate/console: ^10.0|^11.0|^12.0|^13.0
- illuminate/filesystem: ^10.0|^11.0|^12.0|^13.0
- illuminate/support: ^10.0|^11.0|^12.0|^13.0
- laravel/framework: ^10.0|^11.0|^12.0|^13.0
Requires (Dev)
- jpswade/laravel-best-practices: dev-main
- larastan/larastan: ^3.0
- laravel/boost: ^2.0
- laravel/pint: ^1.27
- orchestra/testbench: ^8.0|^9.0|^10.0|^11.0
- phpstan/phpstan-strict-rules: ^2.0
- spatie/db-dumper: ^3.8 || ^4.0
Suggests
- league/flysystem-aws-s3-v3: Needed for db:getFromBackup command to use the S3 Driver.
- spatie/db-dumper: Needed by the db:dump command.
README
The "missing" database toolset for Laravel. A set of commonly used Database Tools for Laravel.
Tested against Laravel 10-13 on PHP 8.1-8.4.
With this package you can:
- Create a database (if it does not exist)
- Dump from another database to file
- Get and unzip from a database backup created by the Spatie Backup package
- Import from file
- Update the charset and collation
- Fixes the "no such function" error by giving SQLite MySQL compatibility by creating the missing function using PDO for SQLite using PHP functions.
- Uses MySQL commands to optimize database tables (using OPTIMIZE TABLE)
Install
Install the package into your Laravel application:
composer require --dev jpswade/laravel-database-tools
Note: It's wise to only install these tools in development by default, as it's rare you should need them in a production environment.
Configure
Publish and customise your own dbtools.php file:
php artisan vendor:publish --provider="Jpswade\LaravelDatabaseTools\ServiceProvider" --tag="config"
This allows you to set the source database and/or filesystem for the backup.
dbtools.database- Define the source database for thedb:dumpcommand, similar to Laravel databases config.dbtools.filesystem- Define the source filesystem for thedb:getFromBackupcommand, similar to Laravel filesystems config.dbtools.filesystem.path- Define the path for thedb:getFromBackupcommand.dbtools.import- Here you can define themethod(command or normal) for thedb:importFromFilecommand.
Note:
- The
db:getFromBackupcommand falls back to thespatie/laravel-backuppackage for configuration.
Usage
The commands are:
db:create- Creates the database schema.db:dump- Fetch a copy of the latest database from the configured server.db:getFromBackup- Download database backup file from backup.db:importFromFile {file?}- Import data from a sql file into a database.db:charset- Changes the charset and collation to whatever the database is set to use.db:optimize- Optimizes your database tables.
SQLite MySQL Compatability Provider
For testing you can add the provider to your Test:
protected function registerServiceProviders(): void { $this->app->register(SqliteMysqlCompatibilityProvider::class); } protected function setUp(): void { parent::setUp(); $this->registerServiceProviders(); }
In production, follow the usual Registering Providers instructions:
In config/app.php, find the providers array and add:
'providers' => [ // Other Service Providers Jpswade\LaravelDatabaseTools\SqliteMysqlCompatibilityProvider::class, ],
Limitations
These are limitations you'll come across if you use certain commands:
- The
db:getFromBackupcommand relies on theleague/flysystem-aws-s3-v3 "^1.0"package, when you use the Amazon S3 Driver as per the Laravel docs. - The
db:dumpcommand depends onspatie/db-dumper. - The commands have only been tested to work with MySQL at the moment, but could be extended to others.
- The
db:importFromFilecommand can only import.sqlfiles. - The
db:optimizecommand only works with MySQL (at the moment).
Contributing
The package ships an opinionated dev-tooling stack alongside the test suite:
composer pint- applies Laravel Pint formatting (Laravel preset +declare_strict_types,strict_comparison,is_null,modernize_types_casting). Config lives inpint.json.composer pint-test- the read-only equivalent used by CI; fails if anything needs reformatting.composer phpunit- test suite (Testbench + PHPUnit).composer phpstan- static analysis at Larastan level 6 withphpstan-strict-rules; pre-existing issues are captured inphpstan-baseline.neon.composer test- runs Pint (test mode), PHPStan, then PHPUnit.
This package also installs Laravel Boost and jpswade/laravel-best-practices as dev dependencies for AI-assisted development. The committed boost.json opts contributors into the relevant skills for Cursor, Claude Code, and Codex; run php artisan boost:install --no-interaction after composer install to materialise those skills into your editor's agent directory. Contributors using a different editor can override locally - boost.json is the maintainer default, not a hard requirement.
CI runs the test suite across the full PHP x Laravel matrix on every push and pull request - see .github/workflows/tests.yml.
Troubleshooting
Class 'League\Flysystem\AwsS3v3\AwsS3Adapter' not found
% composer require league/flysystem-aws-s3-v3:~1.0
Note: Needed for db:getFromBackup command to use the S3 Driver.
Class "League\Flysystem\AwsS3V3\PortableVisibilityConverter" not found
% composer require league/flysystem-aws-s3-v3
Class 'Spatie\DbDumper\Databases\MySql' not found
% composer require spatie/db-dumper
Note: Needed by the db:dump command.