Query both unset and false
Hi Everyone! I love using Convex so far, it is really easy and a lot of great features out of the box. Right now I am trying to figure out a best practice to implement a "soft delete".
I have defined a schema documents:
The problem arrives when I try to only the non-archived documents, this is the filter I am using:
.filter((q) => q.eq("isArchived", undefined))
If I attempt to filter by false instead of undefined I get a typescript error.
And in my restore function, I patch the document by setting isArchived
to false.
I assume it can work by me setting the isArchived: undefined
instead of false
But I feel like I am doing something wrong here?
Can I query an optional, boolean field by both undefined | false
?
P.S. My userId
is a string because I dont have the need for users table atm, I just use Clerk's userId.6 Replies
Hey @CodeWithAntonio , you can use an
q.or
to combine the two conditions (equals undefined or equals false):
https://docs.convex.dev/database/reading-data#combining-operatorsReading Data | Convex Developer Hub
Query and
Something like:
q.or(q.eq(q.field("isArchived"), false), q.eq(q.field("isArchived"), undefined))
Note: for filter, you have to specify q.field
as the first parameter. Otherwise you'll just be finding documents where the string "isArchived" is false
(which will always be the case). This is a rough edge we know about and are thinking about improvingWorks like a charm! I got some "cannot use undefined as filter" message, but it went away after I re-run
npx convex dev
, must've been unsynsced schema or some of my unsaved changes. Thanks for the insight about additional query operator and the q.field
!Something that could be useful, since I come from Prisma background is having the ability for "default" for optional fields 🙂
data:image/s3,"s3://crabby-images/7d552/7d552575c33a4ce11e9bab90139f6681cc114e59" alt="No description"
+1 for defaults
Thanks for the feedback about defaults, we are thinking through the solutions for this problem.
Keep the feedback coming! 🙂