Getting Started
Make sure to first set up your PlanetScale developer environment. Once you’ve installed thepscale CLI, you can interact with PlanetScale and manage your databases straight from the command line.
The database command
This command allows you to create, read, delete, dump, and restore databases.
Usage:
Available sub-commands
| Sub-command | Sub-command flags | Description | Product | 
|---|---|---|---|
| create <DATABASE_NAME> | --region <REGION_NAME>,--plan <PLAN>,--cluster_size <CLUSTER_SIZE> | Create a database with the specified name | Postgres, Vitess | 
| delete <DATABASE_NAME> | --force | Delete the specified database | Postgres, Vitess | 
| dump <DATABASE_NAME> <BRANCH_NAME> | --local-addr <ADDRESS>,--output <DIRECTORY_NAME>,--tables <TABLES_LIST>,--threads <NUMBER_OF_THREADS> (defaults to 16) | Backup and dump the specified database | Postgres, Vitess | 
| list <DATABASE_NAME> | List all databases in the current org | Postgres, Vitess | |
| restore-dump <DATABASE_NAME> <BRANCH_NAME> | --dir <DIRECTORY_NAME>*,--local-addr <ADDRESS>,--overwrite-tables,--threads <NUMBER_OF_THREADS> (defaults to 1),--allow-different-destination,--show-details,--schema-only,--data-only,--starting-table <STARTING_TABLE>,--ending-table <ENDING_TABLE> | Restore the specified database from a local dump directory | Postgres, Vitess | 
| show <DATABASE_NAME> | --web | Retrieve information about a database | Postgres, Vitess | 
* Flag is required
Sub-command flag descriptions
Some of the sub-commands have additional flags unique to the sub-command. This section covers what each of those does. See the above table for which context.| Sub-command flag | Description | Applicable sub-commands | 
|---|---|---|
| --region | Specify the region of the new database. Default is us-east. | create | 
| --plan | Specify the plan for the databas. Currently, scaler_prois the only option and the default. | create | 
| --cluster_size | For Scaler Pro databases, you may specify the cluster size. Default is PS_10 | create | 
| --force | Delete a database without confirmation. | delete | 
| --local-addr <ADDRESS> | Local address to bind and listen for connections. By default the proxy binds to 127.0.0.1 with a random port. | dump,restore-dump | 
| --threads | Number of concurrent threads to use | dump,restore-dump | 
| --output <DIRECTORY_NAME> | Output directory of the dump. By default the dump is saved to a folder in the current directory. | dump | 
| --tables <TABLES_LIST> | Comma separated string of tables to dump. By default, all tables are dumped. | dump | 
| --wheres string | Comma separated string of WHERE clauses to filter the tables to dump. | dump | 
| --replica | Dump from a replica (if available; will fail if not). | dump | 
| --rdonly | Dump from a rdonly tablet (if available; will fail if not). | dump | 
| --keyspace <KEYSPACE_NAME> | Optionally target a specific keyspace to be dumped. Useful for sharded databases. | dump | 
| --shard <SHARD_NAME> | Optional shard to target, must be used with keyspace | dump | 
| --output-format <FORMAT> | Output format for the dump. Options: sql(default),json,csv. | dump | 
| --dir <DIRECTORY_NAME> | Directory containing the files to be used for the restore. | restore-dump | 
| --overwrite-tables | If true, will attempt to DROP TABLE before restoring. | restore-dump | 
| --allow-different-destination | If true, will allow you to restore the files to a database with a different name without needing to rename the existing dump’s files. | restore-dump | 
| --show-details | If true, will add extra output during the restore process. | restore-dump | 
| --schema-only | If true, will only restore the schema files during the restore process. | restore-dump | 
| --data-only | If true, will only restore the data files during the restore process. | restore-dump | 
| --starting-table <TABLE_NAME> | Table to start from for the restore (useful for restarting from a certain point) | restore-dump | 
| --ending-table <TABLE_NAME> | Table to end at for the restore (useful for stopping restore at a certain point) | restore-dump | 
| --web | Perform the action in your web browser | show | 
Available flags
| Flag | Description | 
|---|---|
| -h,--help | Get help with the databasecommand | 
| --org <ORGANIZATION_NAME> | Specify the organization for the database you’re acting upon | 
Global flags
| Command | Description | 
|---|---|
| --api-token <TOKEN> | The API token to use for authenticating against the PlanetScale API. | 
| --api-url <URL> | The base URL for the PlanetScale API. Default is https://api.planetscale.com/. | 
| --config <CONFIG_FILE> | Config file. Default is $HOME/.config/planetscale/pscale.yml. | 
| --debug | Enable debug mode. | 
| -f,--format <FORMAT> | Show output in a specific format. Possible values: human(default),json,csv. | 
| --no-color | Disable color output. | 
| --service-token <TOKEN> | The service token for authenticating. | 
| --service-token-id <TOKEN_ID> | The service token ID for authenticating. | 
NoteThe 
--format flag does not apply to the database dump files created by the dump subcommand. However, you can control the output format using the --output-format flag, which supports SQL (default), JSON, and CSV formats. When using SQL format, dumps are compatible with mydumper.Examples
Create a new scaler_pro database
Command:
new-database was successfully created.
Create a backup of an existing branch:
Command:--output location above that will be used instead.
Export data in different formats:
You can specify the output format when dumping your Vitess database using the--output-format flag:
Export as JSON:
Restore a backup to an existing branch:
Command:pscale v0.218.0 or newer the --allow-different-destination flag is now available. If this flag is provided it will make the steps below about renaming the files unnecessary.
If you opt to import into a database with a different name you will have to make sure you rename the files from your backup beforehand.
For example, the files will be named something like this:
--overwrite-tables flag.

