Vou explicar como campos variados são tratados com um exemplo. O seguinte
Game.java
A classe POJO representa o mapeamento do objeto para o game
documento de cobrança. 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
}
}
Para as
Actions
class você precisa fornecer aos construtores as combinações possíveis. Use o construtor apropriado com id
, type
, etc. Por exemplo, crie um Game
object e salve no banco de dados:Game.Actions actions= new Game.Actions(new Integer(1000));
Game g1 = new Game("G-1", Arrays.asList(actions));
repo.save(g1);
Isso é armazenado na coleção de banco de dados
game
como segue (consultado de mongo
Concha):{
"_id" : ObjectId("5eeafe2043f875621d1e447b"),
"name" : "G-1",
"actions" : [
{
"_id" : 1000
}
],
"_class" : "com.example.demo.Game"
}
Observe as
actions
variedade. Como armazenamos apenas o id
campo no Game.Actions
objeto, apenas esse campo é armazenado. Mesmo que você especifique todos os campos na classe, apenas aqueles fornecidos com valores são mantidos. Estes são mais dois documentos com
Game.Actions
criado com type
somente e id + type
usando os construtores apropriados:{
"_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"
}