[英]Converting DBObject to Java Object while retrieve values from MongoDB
From my Java application, I have stored the values in mongoDB in ArrayList(set of Java objects). 在我的Java应用程序中,我将mongoDB中的值存储在ArrayList(Java对象集)中。 How can I retrieve the data from DBObject 如何从DBObject检索数据
I am storing the data in mongoDB like this: 我将数据存储在mongoDB中,如下所示:
{ "students" : [{"firstName" : "Jesse", "lastName" : "Varnell", "age" : "15", "gender" : "M" }, { "firstName" : "John", "lastName" : "Doe", "age" : "13", "gender" : "F"}] }
I am having the Java Object for the Student like: 我正在为学生提供Java对象:
public class Student {
public String firstName;
public String lastName;
public String age;
public String gender; // M, F
}
I am retrieving the data from mongoDB like: 我正在从mongoDB中检索数据,如:
BasicDBObject query = new BasicDBObject();
query.put("user", username);
DBCursor cursor = theCollection.find(query);
while (cursor.hasNext()) {
DBObject theObj = cursor.next();
//How to get the DBObject value to ArrayList of Java Object?
}
You can do it as follows : 你可以这样做:
List<Student> students = new ArrayList<Student>();
BasicDBObject query = new BasicDBObject();
query.put("user", username);
DBCursor cursor = theCollection.find(query);
while (cursor.hasNext()) {
DBObject theObj = cursor.next();
//How to get the DBObject value to ArrayList of Java Object?
BasicDBList studentsList = (BasicDBList) theObj.get("students");
for (int i = 0; i < studentsList.size(); i++) {
BasicDBObject studentObj = (BasicDBObject) studentsList.get(i);
String firstName = studentObj.getString("firstName");
String lastName = studentObj.getString("lastName");
String age = studentObj.getString("age");
String gender = studentObj.getString("gender");
Student student = new Student();
student.setFirstName(firstName);
student.setLastName(lastName);
student.setAge(age);
student.setGender(gender);
students.add(student);
}
}
You generally use an ORM tool for that (though it wouldn't be meaningful to call it ORM in the case of a non relational database). 您通常使用ORM工具(尽管在非关系数据库的情况下将其称为ORM没有意义)。
There are several such tools. 有几个这样的工具。 I like spring-data, which hides a lot of boiler plate code for you and gives you a simple, clean syntax. 我喜欢spring-data,它为你隐藏了很多样板代码,并为你提供了一个简单,干净的语法。 Something like this: 像这样的东西:
@Repository
public class UserRepositoryImpl implements UserRepository {
private MongoTemplate mongoTemplate;
@Autowired
public UserRepositoryImpl(MongoTemplate mongoTemplate) {
this.mongoTemplate = mongoTemplate;
}
@Override
public User findsUserByUsernameAndPassword(String userName, String encodedPassword) {
return mongoTemplate.findOne(query(where("userName").is(userName).and("encodedPassword").is(encodedPassword)), User.class);
}
}
With the User
class defined as: 将User
类定义为:
@Document(collection = "users")
public class User {
private String userName;
private String encodedPassword;
// snip getters and setters
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.