From adb4a4cc8f253add1cdad58dc2392326a7aa1597 Mon Sep 17 00:00:00 2001 From: Shahriar Shojib Date: Thu, 5 Dec 2024 07:23:13 -0800 Subject: [PATCH] Added mongodb aggregateRaw caveats --- .../150-using-raw-sql/200-raw-queries.mdx | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/content/200-orm/200-prisma-client/150-using-raw-sql/200-raw-queries.mdx b/content/200-orm/200-prisma-client/150-using-raw-sql/200-raw-queries.mdx index d9f95702b4..cb80a2f38d 100644 --- a/content/200-orm/200-prisma-client/150-using-raw-sql/200-raw-queries.mdx +++ b/content/200-orm/200-prisma-client/150-using-raw-sql/200-raw-queries.mdx @@ -851,3 +851,18 @@ const result = await prisma.user.aggregateRaw({ - `pipeline`: An array of aggregation stages to process and transform the document stream via the [aggregation pipeline](https://www.mongodb.com/docs/manual/reference/operator/aggregation-pipeline). - `options`: Additional options to pass to the [`aggregate` command](https://www.mongodb.com/docs/manual/reference/command/aggregate/#command-fields). + +:::info +#### Caveats + +When working with custom objects like `ObjectId` or `Date,` you will have to pass them according to the [MongoDB extended JSON Spec](https://www.mongodb.com/docs/manual/reference/mongodb-extended-json/#type-representations). +Example: +```ts no-lines +const result = await prisma.user.aggregateRaw({ + pipeline: [ + { $match: { _id: { $oid: id } } } +// ^ notice the $oid convention here + ], +}); + +```