Find some values in a mongodb collection?

2019-02-24 09:04发布

Im trying to read a (mongo)userdatabase with java. On the tutorial page I saw how to read the whole collection. I can do something like that:

    DBCursor cursor = col.find();
    while (cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Now if I have a collection with users := name, age, password (...) and whatever. Now I would like to find a name with a password. For example for a login process. Lets say I have two strings: String n and p. If there is a user.equals(n) and a password.equals(p) in the database then login user. How do I have to change my cursor? I saw some query examples on the mongodb java tutorial page, but duh I really dont get it...

Any ideas? Thank you

2条回答
来,给爷笑一个
2楼-- · 2019-02-24 09:58

Awesome, you'll love Mongo.

In the example you posted, the program iterates through a set of results. In the user/password problem you describe what you are actually trying to do is get one document (not a set of documents) based on some criteria.

On the shell that would look like this:

n = "login"
p = "password"

db.users.findOne({ user: n, password: p})

Notice I'm using findOne instead of find which returns a document instead of a cursor to many documents.

Now, lets take a look at the java driver's example:

BasicDBObject query = new BasicDBObject();

query.put("i", 71);
cur = coll.find(query);

while(cur.hasNext()) {
    System.out.println(cur.next());
}

The BasicDBObject creates the query object and then you put different criteria which together form your query.

So instead of query.put("i", 71); you would do something like:

query.put("user", n)
query.put("password", p)

and... instead of the while loop just use findOne instead of find so you don't have to iterate over the result set of 1 object (pointless).

You can read more about findOne() here.

查看更多
家丑人穷心不美
3楼-- · 2019-02-24 10:03

You can query desired data directly:

BasicDBObject query = new BasicDBObject();
query.put("name", "user");
query.put("password", "[YOUR ENCRYPTED PASSWORD HERE]");

DBCollection collection = db.getCollection("yourcollectionname");
DBCursor cursor = collection.find(query);

while (cursor.hasNext()) {
  //do something with cursor.next();
}

As was suggested you need to check count of results returned by find() method to make sure only single record matches your query.

查看更多
登录 后发表回答