From 985aa5f188f242da72648d6a201ff8d0872e5d9c Mon Sep 17 00:00:00 2001 From: Martin Kersner Date: Mon, 20 Nov 2023 18:18:57 +0900 Subject: [PATCH] Use faster query to fetch the latest aggregate (#945) --- api/src/aggregate/aggregate.service.ts | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/api/src/aggregate/aggregate.service.ts b/api/src/aggregate/aggregate.service.ts index 878ec9f35..efa688fe7 100644 --- a/api/src/aggregate/aggregate.service.ts +++ b/api/src/aggregate/aggregate.service.ts @@ -61,13 +61,16 @@ export class AggregateService { */ async findLatest(latestAggregateDto: LatestAggregateDto) { const { aggregatorHash } = latestAggregateDto - return await this.prisma.aggregate.findFirst({ - where: { aggregator: { aggregatorHash } }, - orderBy: [ - { - timestamp: 'desc' - } - ] - }) + const query = Prisma.sql`SELECT aggregate_id as id, timestamp, value, aggregator_id as "aggregatorId" + FROM aggregates + WHERE aggregator_id = (SELECT aggregator_id FROM aggregators WHERE aggregator_hash = ${aggregatorHash}) + ORDER BY timestamp DESC + LIMIT 1;` + const result: Prisma.AggregateScalarFieldEnum[] = await this.prisma.$queryRaw(query) + if (result.length == 1) { + return result[0] + } else { + throw Error(`Expected one row. Received ${result.length}`) + } } }