Combine queries into batches
This commit is contained in:
@@ -33,37 +33,31 @@ export async function loader({ context }: { context: RequestContext }) {
|
||||
|
||||
if (!currentUser) throw new Response(null, { status: 401 });
|
||||
|
||||
const d1Promises = [];
|
||||
const batchStatements = [];
|
||||
|
||||
for (const itemType of ["appeals", "inactivity_notices", "reports"])
|
||||
d1Promises.push(
|
||||
for (const itemType of ["appeals", "inactivity_notices", "reports"]) {
|
||||
batchStatements.push(
|
||||
context.env.D1.prepare(
|
||||
`SELECT *
|
||||
FROM ${itemType}
|
||||
WHERE json_extract(user, '$.id') = ?
|
||||
ORDER BY created_at DESC;`,
|
||||
)
|
||||
.bind(currentUser.id)
|
||||
.all(),
|
||||
`SELECT * FROM ${itemType} WHERE json_extract(user, '$.id') = ? ORDER BY created_at DESC;`,
|
||||
).bind(currentUser.id),
|
||||
);
|
||||
|
||||
const settledPromises = await Promise.allSettled(d1Promises);
|
||||
let etData: { [k: string]: any } | null = null;
|
||||
|
||||
if (currentUser.permissions & (1 << 3)) {
|
||||
etData = await context.env.D1.prepare(
|
||||
"SELECT name, points, roblox_id FROM et_members WHERE id = ?;",
|
||||
)
|
||||
.bind(currentUser.id)
|
||||
.first();
|
||||
}
|
||||
|
||||
return {
|
||||
etData,
|
||||
items: settledPromises.map((p) => {
|
||||
if (p.status === "fulfilled") return p.value.results;
|
||||
if (currentUser.permissions & (1 << 3))
|
||||
batchStatements.push(
|
||||
context.env.D1.prepare(
|
||||
"SELECT name, points, roblox_id FROM et_members WHERE id = ? LIMIT 1;",
|
||||
).bind(currentUser.id),
|
||||
);
|
||||
|
||||
return null;
|
||||
const batchResults = await context.env.D1.batch(batchStatements);
|
||||
|
||||
return {
|
||||
etData: batchResults.at(3)?.results?.at(0) as { [k: string]: any } | null,
|
||||
items: batchResults.map((r) => {
|
||||
if (r.success) return r.results;
|
||||
|
||||
return [];
|
||||
}) as any as ({ [k: string]: any }[] | null)[],
|
||||
permissions: currentUser.permissions as number,
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user