我正在使用mongodb来存储用户信息。
我想创建一个从数据库获取信息,创建Player对象并将其插入Player数组的方法。
这是下面的方法
public ArrayList<Player> getArrayOfPlayers(){
ArrayList<Player> savePlayers = new ArrayList<Player>();
DB db = connectToMongo();
DBCollection coll = db.getCollection("players");
DBCursor cursor = coll.find();
while(cursor.hasNext()) {
String tempName = (String)cursor.next().get("name");
String tempSession = (String)cursor.next().get("session");
String tempStringScore = (String)cursor.next().get("score");
int tempScore = Integer.parseInt(tempStringScore);
Player player = new Player(tempName,tempSession,tempScore);
savePlayers.add(player);
}
return savePlayers;
}
我有4个用户存储在数据库中,当我尝试首先调用该方法然后打印名称时,例如,我遇到了异常。
我在方法的while之外使用了try-catch,但捕获了异常,但随后它仅打印了第一个用户的名称。似乎在第二次迭代中引发了异常。
这是我收到的异常(exception)消息。
java.lang.RuntimeException: no more
com.mongodb.DBApiLayer$Result.next(DBApiLayer.java:394)
com.mongodb.DBApiLayer$Result.next(DBApiLayer.java:360)
com.mongodb.DBCursor._next(DBCursor.java:445)
com.mongodb.DBCursor.next(DBCursor.java:525)
machine.DAOMongodb.getArrayOfPlayers(DAOMongodb.java:74)
machine.testDB.doGet(testDB.java:43)
javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
最佳答案
调用cursor.next()
方法,您将获得下一个元素并增加光标位置。
您为每次迭代调用cursor.next()
3次,因此在第二次迭代中,游标中没有“更多”元素。
将元素保存在迭代局部变量中:
while(cursor.hasNext()) {
DBObject tobj = cursor.next();
String tempName = (String)tobj.get("name");
String tempSession = (String)tobj.get("session");
String tempStringScore = (String)tobj.get("score");
int tempScore = Integer.parseInt(tempStringScore);
Player player = new Player(tempName,tempSession,tempScore);
savePlayers.add(player);
}