sql >> Databasteknik >  >> NoSQL >> MongoDB

Möjligt att jämföra datumsträngar i mongodb?

Om du vill välja poster, använd ett datumintervall:

db.collection.find({
    created: { "$gte": new Date("2013-05-27"), "$lt": new Date("2013-05-28") }
})

Och det väljer alla ingående timmar, minuter etc, som faller mellan de två datumen.

Så du bör vara att försöka använda datumvärdena och inte tvinga till strängar.

Om du vill ha detta för att göra aggregering eller på annat sätt behov resultaten i formatet endast en dag gör sedan detta med $project och datum för operatörer :

db.collection.aggregate([
    // Still match on the normal date forms, this time whole month
    { "$match": {
        created: { 
           "$gte": new Date("2013-05-01"), 
           "$lt": new Date("2013-05-31") 
        }
    }},

    // Project the date
    { "$project": {
        "date": {
            "year"  : { "$year"  : "$created" },
            "month" : { "$month" : "$created" },
            "day":  : { "$dayOfMonth": "$created" }
        },
        "title": 1
    }},

    // Group on day and title
    { "$group": {
        "_id": {
            "date"  : "$date",
            "title" : "$title"
        },
        "count": { "$sum": 1 }
    }},

    // Sort by date
    { "$sort": { 
        "_id.date.year": 1,
        "_id.date.month": 1,
        "_id.date.day": 1,
    }},

    // Project nicer dates and document
    { "$project": {
        "_id": 0,
        "date": { "$concat": [
            { "$substr": [ "$_id.date.year", 0, 4 ] },
            "-",
            { "$substr": [ "$_id.date.month", 0, 2 ] },
            "-",
            { "$substr": [ "$_id.date.day", 0, 2 ] }
        ]},
        "title": "$_id.title",
        "count": 1
    }}
])



  1. Om MongoDB, varför använder vi det? MongoDB:s terminologi och implementering

  2. Hur man använder $query, $hint eller $explain från Java

  3. Mongodb Aggregation Framework | Gruppera över flera värden?

  4. Lägg till sekundär replikuppsättning i samma maskin?