Skip to content

Commit

Permalink
feat: expose rows_{read,written} in D1 meta (#4686)
Browse files Browse the repository at this point in the history
  • Loading branch information
mrbbot authored Jan 10, 2024
1 parent 86d90fa commit 4f6999e
Show file tree
Hide file tree
Showing 4 changed files with 24 additions and 2 deletions.
7 changes: 7 additions & 0 deletions .changeset/late-clocks-reply.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
"miniflare": minor
---

feat: expose `rows_read` and `rows_written` in D1 result `meta`

`rows_read`/`rows_written` contain the number of rows read from/written to the database engine when executing a query respectively. These numbers may be greater than the number of rows returned from/inserted by a query. These numbers form billing metrics when your Worker is deployed. See https://developers.cloudflare.com/d1/platform/pricing/#billing-metrics for more details.
8 changes: 6 additions & 2 deletions packages/miniflare/src/workers/d1/database.worker.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,10 @@ interface D1SuccessResponse {
duration: number;
changes: number;
last_row_id: number;
changed_db?: boolean;
size_after?: number;
changed_db: boolean;
size_after: number;
rows_read: number;
rows_written: number;
};
}
interface D1FailureResponse {
Expand Down Expand Up @@ -143,6 +145,8 @@ export class D1DatabaseObject extends MiniflareDurableObject {
last_row_id: afterChanges.lastRowId,
changed_db: changed,
size_after: afterSize,
rows_read: cursor.rowsRead,
rows_written: cursor.rowsWritten,
},
};
};
Expand Down
3 changes: 3 additions & 0 deletions packages/miniflare/src/workers/shared/sql.worker.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,9 @@ export interface TypedSqlStorage {
export interface TypedSqlStorageCursor<R extends TypedResult = TypedResult> {
raw(): IterableIterator<R[keyof R][]>;
[Symbol.iterator](): IterableIterator<R>;
readonly columnNames: string[];
readonly rowsRead: number;
readonly rowsWritten: number;
}
export interface TypedSqlStorageStatement<
P extends TypedValue[] = TypedValue[],
Expand Down
8 changes: 8 additions & 0 deletions packages/miniflare/test/plugins/d1/suite.ts
Original file line number Diff line number Diff line change
Expand Up @@ -229,6 +229,8 @@ test("D1PreparedStatement: run", async (t) => {
last_row_id: result.meta.last_row_id,
served_by: "miniflare.db",
size_after: result.meta.size_after,
rows_read: 3,
rows_written: 0,
},
});

Expand All @@ -251,6 +253,8 @@ test("D1PreparedStatement: run", async (t) => {
last_row_id: 4,
served_by: "miniflare.db",
size_after: result.meta.size_after,
rows_read: 2,
rows_written: 2,
},
});

Expand Down Expand Up @@ -282,6 +286,8 @@ test("D1PreparedStatement: run", async (t) => {
last_row_id: 5,
served_by: "miniflare.db",
size_after: result.meta.size_after,
rows_read: 1,
rows_written: 1,
},
});
});
Expand Down Expand Up @@ -309,6 +315,8 @@ test("D1PreparedStatement: all", async (t) => {
last_row_id: result.meta.last_row_id,
served_by: "miniflare.db",
size_after: result.meta.size_after,
rows_read: 3,
rows_written: 0,
},
});

Expand Down

0 comments on commit 4f6999e

Please sign in to comment.