Complex Filtering
I'm a bit confused on how i should go about conditionally filtering my queries and filtering entries in general.
I have a table with two fields by which I want to filter the results. But the args i provide in the query function are optional.
Let's take the field "map" because that's the easiest to filter out of the two
In the image below i filter the returned documents. Is this an efficient way to filter queries?
I mean it works, but I do want to make it more efficient than to get everything and then filter, because who knows when the table could have thousands of entries, which as i understood from the indexing docs, does take longer to go through all the entries.
data:image/s3,"s3://crabby-images/739e8/739e8477903e393ae8300f2ab68fc7b5edae7e80" alt="No description"
9 Replies
And the second field named
tags
is more complicated
in the db it's a list of objects structured as so
basically i take all the objects in the tags field with the category "side"
and i check if the new list has atleast one of the entries in tags.sides
argument if isn't empty
and then i further filter the with tags.abilities
in the same way, checking if it has atleast one of the entries
and then i return the posts that meet all these conditions
But my worry still is that it isn't the most efficient way to filter, as i'm going through all the posts in the db.data:image/s3,"s3://crabby-images/2768a/2768a5fff037b6fdf3c930102a25e7ff3a5af805" alt="No description"
data:image/s3,"s3://crabby-images/66a1a/66a1a98cac42aeb2f0b68d8c4e2426025671a952" alt="No description"
I was planning to do an if condition inside the
db.query().filter()
but that didn't seem to work
i'm not the most well versed with backend, so forgive me if what i've explained is not clear enough š
I'm headed to bed, but a few thoughts:
- it's ok not to do this the most efficient way for now, Convex being relational helps make it easy to change data access patterns later
- for doing a condition inside the filter it would help to see code, that's a reasonable thing to do! here's an example of that: https://docs.convex.dev/using/database-queries#equality-conditions
- indexes are the next optimization after that. It sounds like an index on the posts table by map would be useful here, since you want to grab all the posts of a given map value
- for the second part, there are ways to data model this - but you could wait to get into this until you have thousands of posts with the same map value to do it, because doing this in memory as you already are sure is convenient
Querying the Database | Convex Developer Hub
Push queries down to the database.
it's ok not to do this the most efficient way for now, Convex being relational helps make it easy to change data access patterns laterš got it!
for doing a condition inside the filter it would help to see code, that's a reasonable thing to do!About this, i still don't understand how i would make it filter the query, only if my map arg is not
""
or "All"
should i do it like so?
I'll test it now anyway, but i just want your input on if this a "proper" way to do it
indexes are the next optimization after that. It sounds like an index on the posts table by map would be useful here, since you want to grab all the posts of a given map valueI did read up on indexing, and it did sound interesting. I'll go through it once more and try to put it to use āØ
for the second part, there are ways to data model this - but you could wait to get into this until you have thousands of posts with the same map value to do it, because doing this in memory as you already are sure is convenientOh, i see. i think i'll need more time working with backend to get into it then š This is only the second time i'm even doing anything database related
I did a little messing around and made it to this
and it works fine as far as i can tell so, yay?
data:image/s3,"s3://crabby-images/68939/68939416295d23be3c252db92065617cb4cfb87b" alt="No description"
this looks great
oh I misunderstood about the "conditional filtering," I thought the filter was the condition. Yeah, I would put the if statement outside of the query and write two queries just like you did.
ah, i was confused by your first reply to that
I was thinking there was a way to do that within
filter()
and dug through the api docs for a good minute šsorry about that!
š Got it done in the end
Thanks so much for the help!!