Mongo query to find record between specific time

Ankush Madankar

I have collections with DateTime field which have datetime value saved in UTC, with time.

I like to find all record between time 8 AM to 6 PM regardless date. I have tried following query:

{ $expr: { $gte: [ { $hour: "$DateTime" }, 8 ]} }

This query is working fine to get record after 8 AM, regardless date. I am unable to find query with $lte in same match. This query is not working:

{ $expr: { $gte: [ { $hour: "$DateTime" }, 8 ], $lte: [ { $hour: "$DateTime" }, 18 ]} }

Error: An object representing an expression must have exactly one field: { $gte: [ { $hour: "$DateTime" }, 8 ], $lte: [ { $hour: "$DateTime" }, 18 ] }

Any help would be appreciated. If this can be done in Mongo dotnet core then that would be great using lamda expression.

ray

One of the simple ways to perform time-only comparison will be convert to string using $dateToString and perform string comparison.

db.collection.aggregate([
  {
    $match: {
      $expr: {
        $and: [
          {
            $gte: [
              {
                "$dateToString": {
                  "date": "$DateTime",
                  "format": "%H:%M:%S"
                }
              },
              "08:30:00"
            ]
          },
          {
            $lte: [
              {
                "$dateToString": {
                  "date": "$DateTime",
                  "format": "%H:%M:%S"
                }
              },
              "18:30:00"
            ]
          }
        ]
      }
    }
  }
])

Here is the Mongo playground for your reference.

Collected from the Internet

Please contact [email protected] to delete if infringement.

edited at
0

Comments

0 comments
Login to comment

Related

Query to find records between specific time period

Query to select record of last five days but in between a specific time

Decrease find duplicate record query execution time

Snowflake Sql Query to find the time taken between specific task flow for completing the coding task for an encounter

Count Columns query with between specific time

Query to find the time difference between successive events

How to reduce execution time in this mongo db find query?

How to write Mongo query to find data between dates

How to find record times between two time spans

Measure time of query in Mongo

mongo jpa between query

How do I find the time difference between the first record and the current record

Spark DataFrame query between 2 specific Time Range

Making a query to get elements active on a time between 2 specific dates

How can I find between two specific datas with MongoDB Query

SQL Query to find the next staus and get time between them

formatted response for find query mongo

Mongo with java - find query with batchsize

Mongo find() query with regexp not filtering

Mongo db In Query with limit for each record

Specific record from Select Query

Query Kafka topic for specific record

Mongo find all objects that are created within specific hours when using systematic time format

Find Latest Record With Specific Values

MongoDB Aggregate Query to show all objects with time between a specific time range

How to add result of a mongo find query into another find query

Query mongo to detect value changes in time series

SELECT the record (time) of a specific change for one ID

Mongo find query only returns one result

TOP Ranking

  1. 1

    Failed to listen on localhost:8000 (reason: Cannot assign requested address)

  2. 2

    pump.io port in URL

  3. 3

    How to import an asset in swift using Bundle.main.path() in a react-native native module

  4. 4

    Loopback Error: connect ECONNREFUSED 127.0.0.1:3306 (MAMP)

  5. 5

    Compiler error CS0246 (type or namespace not found) on using Ninject in ASP.NET vNext

  6. 6

    BigQuery - concatenate ignoring NULL

  7. 7

    Spring Boot JPA PostgreSQL Web App - Internal Authentication Error

  8. 8

    ggplotly no applicable method for 'plotly_build' applied to an object of class "NULL" if statements

  9. 9

    ngClass error (Can't bind ngClass since it isn't a known property of div) in Angular 11.0.3

  10. 10

    How to remove the extra space from right in a webview?

  11. 11

    Change dd-mm-yyyy date format of dataframe date column to yyyy-mm-dd

  12. 12

    Jquery different data trapped from direct mousedown event and simulation via $(this).trigger('mousedown');

  13. 13

    maven-jaxb2-plugin cannot generate classes due to two declarations cause a collision in ObjectFactory class

  14. 14

    java.lang.NullPointerException: Cannot read the array length because "<local3>" is null

  15. 15

    How to use merge windows unallocated space into Ubuntu using GParted?

  16. 16

    flutter: dropdown item programmatically unselect problem

  17. 17

    Pandas - check if dataframe has negative value in any column

  18. 18

    Nuget add packages gives access denied errors

  19. 19

    Can't pre-populate phone number and message body in SMS link on iPhones when SMS app is not running in the background

  20. 20

    Generate random UUIDv4 with Elm

  21. 21

    Client secret not provided in request error with Keycloak

HotTag

Archive