sql >> Database >  >> NoSQL >> MongoDB

Hoe kan ik controleren of een veld al dan niet bestaat in MongoDB?

U kunt de $exists . gebruiken operator in combinatie met de . notatie. De kale query in de mongo-shell zou er als volgt uit moeten zien:

db.yourcollection.find({ 'otherInfo.text' : { '$exists' : true }})

En een testcase in Java zou er als volgt uit kunnen zien:

    BasicDBObject dbo = new BasicDBObject();
    dbo.put("name", "first");
    collection.insert(dbo);

    dbo.put("_id", null);
    dbo.put("name", "second");
    dbo.put("otherInfo", new BasicDBObject("text", "sometext"));
    collection.insert(dbo);

    DBObject query = new BasicDBObject("otherInfo.text", new BasicDBObject("$exists", true));
    DBCursor result = collection.find(query);
    System.out.println(result.size());
    System.out.println(result.iterator().next());

Uitgang:

1
{ "_id" : { "$oid" : "4f809e72764d280cf6ee6099"} , "name" : "second" , "otherInfo" : { "text" : "sometext"}}


  1. Elementen filteren in Redis

  2. Hoe ClusterControl automatisch databaseherstel en failover uitvoert

  3. Mongodb - aggregatie $push indien voorwaardelijk

  4. opdrachtregelauthenticatie van mongo mislukt