Jeg vil forklare, hvordan varierende felter håndteres med et eksempel. Følgende Game.java
POJO-klassen repræsenterer objekttilknytningen til game
indsamlingsdokument.
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
}
}
Til Actions
klasse skal du give konstruktører de mulige kombinationer. Brug den relevante konstruktør med id
, type
osv. Opret f.eks. et Game
objekt og gem i databasen:
Game.Actions actions= new Game.Actions(new Integer(1000));
Game g1 = new Game("G-1", Arrays.asList(actions));
repo.save(g1);
Dette er gemt i databasesamlingen game
som følger (forespørges fra mongo
skal):
{
"_id" : ObjectId("5eeafe2043f875621d1e447b"),
"name" : "G-1",
"actions" : [
{
"_id" : 1000
}
],
"_class" : "com.example.demo.Game"
}
Bemærk actions
array. Da vi kun havde gemt id
feltet i Game.Actions
objekt, er kun det felt gemt. Selvom du angiver alle felterne i klassen, er det kun dem, der er forsynet med værdier, der bevares.
Dette er yderligere to dokumenter med Game.Actions
oprettet med type
kun og id + type
ved hjælp af de relevante konstruktører:
{
"_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"
}