silverbullet/plugos/sqlite/deno-sqlite/bench.ts

89 lines
1.9 KiB
TypeScript

import {
bench,
runBenchmarks,
} from "https://deno.land/std@0.135.0/testing/bench.ts";
import { DB } from "./mod.ts";
if (Deno.args[0]) {
try {
await Deno.remove(Deno.args[0]);
} catch (_) {
// ignore
}
}
const dbFile = Deno.args[0] || ":memory:";
const db = new DB(dbFile);
db.query(
"CREATE TABLE users (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, balance INTEGER)",
);
/** Performance of insert statements (1 insert). */
const names = "Deno Land Peter Parker Clark Kent Robert Parr".split(" ");
bench({
name: "insert 10 000 (named)",
runs: 100,
func: (b): void => {
b.start();
const query = db.prepareQuery(
"INSERT INTO users (name, balance) VALUES (:name, :balance)",
);
db.query("begin");
for (let i = 0; i < 10_000; i++) {
query.execute({ name: names[i % names.length], balance: i });
}
db.query("commit");
b.stop();
},
});
bench({
name: "insert 10 000 (positional)",
runs: 100,
func: (b): void => {
b.start();
const query = db.prepareQuery(
"INSERT INTO users (name, balance) VALUES (?, ?)",
);
db.query("begin");
for (let i = 0; i < 10_000; i++) {
query.execute([names[i % names.length], i]);
}
db.query("commit");
b.stop();
},
});
/** Performance of select statements (select all; 10_000). */
bench({
name: "select 10 000 (select all)",
runs: 100,
func: (b): void => {
b.start();
db.query(
"SELECT name, balance FROM users LIMIT 10000",
);
b.stop();
},
});
/** Performance of select statements (select individually; 10_000). */
bench({
name: "select 10 000 (select first)",
runs: 100,
func: (b): void => {
b.start();
const query = db.prepareQuery(
"SELECT name, balance FROM users WHERE id = ?",
);
for (let id = 1; id <= 10_000; id++) {
query.first([id]);
}
b.stop();
},
});
runBenchmarks();