Я объясню, как обрабатываются различные поля на примере. Следующий класс Game.java
POJO представляет сопоставление объекта с документом коллекции game
.
public class Game {
String name;
List<Actions> actions;
public Game(String name, List<Actions> actions) {
this.name = name;
this.actions = actions;
}
public String getName() {
return name;
}
public List<Actions> getActions() {
return actions;
}
// other get/set methods, override, etc..
public static class Actions {
Integer id;
String type;
public Actions() {
}
public Actions(Integer id) {
this.id = id;
}
public Actions(Integer id, String type) {
this.id = id;
this.type = type;
}
public Integer getId() {
return id;
}
public String getType() {
return type;
}
// other methods
}
}
Для класса Actions
вам необходимо предоставить конструкторам возможные комбинации. Используйте соответствующий конструктор с id
, type
, et c. Например, создайте объект Game
и сохраните его в базе данных:
Game.Actions actions= new Game.Actions(new Integer(1000));
Game g1 = new Game("G-1", Arrays.asList(actions));
repo.save(g1);
Он хранится в коллекции базы данных game
следующим образом (запрашивается из mongo
оболочки):
{
"_id" : ObjectId("5eeafe2043f875621d1e447b"),
"name" : "G-1",
"actions" : [
{
"_id" : 1000
}
],
"_class" : "com.example.demo.Game"
}
Обратите внимание на массив actions
. Поскольку мы сохранили только поле id
в объекте Game.Actions
, сохраняется только это поле. Несмотря на то, что вы указываете все поля в классе, сохраняются только те, которые имеют значения.
Это еще два документа с Game.Actions
, созданными только с type
, и id + type
с использованием соответствующих конструкторов:
{
"_id" : ObjectId("5eeb02fe5b86147de7dd7484"),
"name" : "G-9",
"actions" : [
{
"type" : "type-x"
}
],
"_class" : "com.example.demo.Game"
}
{
"_id" : ObjectId("5eeb034d70a4b6360d5398cc"),
"name" : "G-11",
"actions" : [
{
"_id" : 2,
"type" : "type-y"
}
],
"_class" : "com.example.demo.Game"
}