How to filter on date ranges in Prisma
When fetching records from your database, it’s very common to want to filter records based on date ranges. Fortunately, the Prisma ORM makes this very easy with filter conditions and operators.
When working with date columns, you’ll most commonly be using gt
(greater than), gte
(greater than or equal to), lt
(less than), and lte
(less than or equal to). When used in conjunction, these let you write where clauses that filter records based on any date range.
Filter records after a certain date
If you need to filter records after a certain date, you can use either the gte
or gt
operator depending on your use case. If you want to include the specified date you should use gte
, otherwise you should use gt
.
Here’s an example of fetching post
records that were created on or after August 1, 2023.
const posts = await prisma.post.findMany({ where: { createdAt: { gte: new Date('2023-08-01'), // Earliest date }, }, });
Filter records before a certain date
Similarly, if you want to filter records before a certain date, you can use either the lte
or lt
operator.
Here’s an example of fetching post
records that were created on or before August 31, 2023.
const posts = await prisma.post.findMany({ where: { createdAt: { lte: new Date('2023-08-31'), // Latest date }, }, });
Filter records between a date range
Putting this together, if you want to filter records between a start and end date, you can use both gte
/gt
and lte
/lt
in conjunction.
Here’s an example of how you would fetch all posts created in the month of August.
const posts = await prisma.post.findMany({ where: { createdAt: { gte: new Date('2023-08-01'), // Start of date range lte: new Date('2023-08-31'), // End of date range }, }, });
Filtering in Prisma
Now you can use these filter operations to fetch records from your database using Prisma.
If you need to do any other kinds of complex filtering in Prisma, you should check out the official Prisma Client API reference.
UI tools
If you're looking for a UI-based tool to inspect and manage records in your database, you can check out Basedash which automatically generates a collaborative interface on your SQL database. It supports filtering on date ranges and much more.
Invite only
Fast. Opinionated. Collaborative. Local-first. Keyboard centric. Crafted to the last pixel. We've got 50 slots for Alpha access.
How to automate Prisma migrations in a CI/CD pipeline
Max Musing
How to implement soft deletes in Prisma
Max Musing
How to use the shadow database in Prisma
Kris Lachance
How to reset and seed a Prisma database
Max Musing
UUID vs GUID vs CUID vs NanoID: A guide to database primary keys
Max Musing
How to generate UUIDs in Prisma
Max Musing