Alpha database migration guide
D1's open beta launched in October 2023, and newly created databases use a different underlying architecture that is significantly more reliable and performant, with increased database sizes, improved query throughput, and reduced latency.
This guide will instruct you to recreate alpha D1 databases on our production-ready system.
Prerequisites
Section titled “Prerequisites”- You have the
wrangler
command-line tool installed - You are using
wrangler
version3.33.0
or later (released March 2024) as earlier versions do not have the--remote
flag required as part of this guide - An 'alpha' D1 database. All databases created before July 27th, 2023 (release notes) use the alpha storage backend, which is no longer supported and was not recommended for production.
1. Verify that a database is alpha
Section titled “1. Verify that a database is alpha”npx wrangler d1 info <database_name>
If the database is alpha, the output of the command will include version
set to alpha
:
...│ version │ alpha │...
2. Create a manual backup
Section titled “2. Create a manual backup”npx wrangler d1 backup create <alpha_database_name>
3. Download the manual backup
Section titled “3. Download the manual backup”The command below will download the manual backup of the alpha database as .sqlite3
file:
npx wrangler d1 backup download <alpha_database_name> <backup_id> # See available backups with wrangler d1 backup list <database_name>
4. Convert the manual backup into SQL statements
Section titled “4. Convert the manual backup into SQL statements”The command below will convert the manual backup of the alpha database from the downloaded .sqlite3
file into SQL statements which can then be imported into the new database:
sqlite3 db_dump.sqlite3 .dump > db.sql
Once you have run the above command, you will need to edit the output SQL file to be compatible with D1:
-
Remove
BEGIN TRANSACTION
andCOMMIT;
from the file. -
Remove the following table creation statement:
CREATE TABLE _cf_KV (key TEXT PRIMARY KEY,value BLOB) WITHOUT ROWID;
5. Create a new D1 database
Section titled “5. Create a new D1 database”All new D1 databases use the updated architecture by default.
Run the following command to create a new database:
npx wrangler d1 create <new_database_name>
6. Run SQL statements against the new D1 database
Section titled “6. Run SQL statements against the new D1 database”npx wrangler d1 execute <new_database_name> --remote --file=./db.sql
7. Delete your alpha database
Section titled “7. Delete your alpha database”To delete your previous alpha database, run:
npx wrangler d1 delete <alpha_database_name>
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark