Cloudflare Docs
D1
Visit D1 on GitHub
Set theme to dark (⇧+D)

Pricing

D1 bills based on:

  • Usage: Queries you issue against D1 will count as rows read, rows written, or both (for transactions or batches).
  • Scale-to-zero: You are not billed for “hours” or “capacity units”. If you are not issuing queries against your database, you are not billed for compute.
  • Storage: You are only billed for storage above the included limits of your plan.

​​ Billing metrics

Workers FreeWorkers Paid
Rows read5 million / dayFirst 25 billion / month included + $0.001 / million rows
Rows written100,000 / dayFirst 50 million / month included + $1.00 / million rows
Storage (per GB stored)1GB (total)First 5GB included + $0.75 / GB-mo

​​ Definitions

  1. Rows read measure how many rows a query reads (scans), regardless of the size of each row. For example, if you have a table with 5000 rows and run a SELECT * FROM table as a full table scan, this would count as 5,000 rows read. A query that filters on an unindexed column may return fewer rows to your Worker, but is still required to read (scan) more rows to determine which subset to return.
  2. Rows written measure how many rows were written to D1 database. A query that INSERT 10 rows into a users table would count as 10 rows written.
  3. Row size or the number of columns in a row does not impact how rows are counted. A row that is 1 KB and a row that is 100 KB both count as one row.
  4. Definining indexes on your table(s) reduce the number of rows read by a query when filtering on that indexed field. For example, if the users table has an index on a timestamp column created_at, the query SELECT * FROM users WHERE created_at > ?1 would only need to read a subset of the table.
  5. Indexes will add an additional written row when writes include the indexed column, as there are two rows written: one to the table itself, and one to the index. The performance benefit of an index and reduction in rows read will, in nearly all cases, offset this additonal write.
  6. Storage is based on gigabytes stored per month, and is based on the sum of all databases in your account. Tables and indexes both count towards storage consumed.
  7. Free limits reset daily at 00:00 UTC. Monthly included limits reset based on your monthly subscription renewal date, which is determined by the day you first subscribed.
  8. There are no data transfer (egress) or throughput (bandwidth) charges for data accessed from D1.

​​ Frequently Asked Questions

Frequently asked questions related to D1 pricing:

  • Will D1 always have a free tier?

Yes, the Workers free tier will always include the ability to prototype and experiment with D1 for free.

  • What happens if I exceed the daily limits on reads & writes, or the total storage limit, on the free tier?

When your account hits the daily read and/or write limits, you will not be able to issue queries against D1. The D1 API will return errors to your client indicating that your daily limits have been exceeded. Once you have reached your included storage limit, you will need to delete unused databases or clean up stale data before you can insert new data, create or alter tables or create indexes and triggers.

Upgrading to the Paid plan will remove these limits, typically within minutes.

  • What happens if I exceed the monthly included reads, writes and/or storage on the paid tier?

You will be billed for the additional reads, writes and storage according to D1’s pricing metrics.

  • When will D1 start billing me?

For Workers Paid tier users, we intend to start billing for additional usage beyond the included reads, writes and storage by (no earlier than) September 2023. We will notify all customers via email (the super administrator address on their account) prior to this change.

  • How can I estimate my (eventual) bill?

Every query returns a meta object that contains a total count of the rows read (rows_read) and rows written (rows_written) by that query. For example, a query that performs a full table scan (for instance, SELECT * FROM users) from a table with 5000 rows would return a rows_read value of 5000:


"meta": {
"duration": 0.20472300052642825,
"size_after": 45137920,
"rows_read": 5000,
"rows_written": 0
}

These are also included in the D1 Cloudflare dashboard and the analytics API, allowing you to attribute read and write volumes to specific databases, time periods, or both.

  • Does D1 charge for data transfer / egress?

No.

  • Does D1 charge additional for additional compute?

D1 itself does not charge for additional compute. Workers querying D1 and computing results: for example, serializing results into JSON and/or issuing queries, are billed per Workers pricing, in addition to your D1 specific usage.

  • Do queries I issue from the dashboard or wrangler (the CLI) count as billable usage?

Yes: any queries you issue against your database, including INSERTing existing data into a new database, table scans (SELECT * FROM table), or creating indexes count as either reads or writes.

  • Can I use an index to reduce the number of rows read by a query?

Yes, you can use an index to reduce the number of rows read by a query. Creating indexes for your most queried tables and filtered columns reduce how much data is scanned and improve query performance at the same time. If you have a read-heavy workload (most common), this can be particularly advantageous. Writing to columns referenced in an index will add at least one (1) additional row written to account for updating the index, but this is typically offset by the reduction in rows read due to the benefits of an index.

  • Does a freshly created database, and/or an empty table with no rows, contribute to my storage?

Yes, although minimal. An empty table consumes at least a few kilobytes, based on the number of columns (table width) in the table. An empty database consumes approximately 100KB of storage.