MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Morphia List>> return O elemento incorporado não é um DBObject na operação de localização


Morphia vê Map como uma referência de banco de dados para outro documento em vez de vê-lo como uma classe incorporada e tratá-lo como um documento. A solução seria anotar o Map @Embedded, mas isso não é possível pois você não pode editar a classe Map.

Existe uma maneira de obter algo semelhante ao que você está tentando criar outra classe e definir o Map como uma propriedade dessa classe e anotá-lo como @Embedded.

Altere a classe Temp:
public class Temp {
    @Id String _id;

    @Embedded // CHANGE HERE
    List<MapProxy> strings; // CHANGE HERE

    public Temp(){
        strings=new LinkedList<MapProxy>(); // CHANGE HERE
    }

    public static void main(String...args) throws UnknownHostException, MongoException{
        Mongo mongo=null;
        Morphia morphia=null;
        Datastore ds=null;
        mongo = new Mongo();
        morphia = new Morphia();
        morphia.map(Temp.class);
        ds = morphia.createDatastore(mongo, "test2");
        Temp t = new Temp();
        t._id ="hi";      
        MapProxy mp = new MapProxy(); // CHANGE HERE    
        mp.m.put("Hi","1"); // CHANGE HERE
        mp.m.put("Hi2",2); // CHANGE HERE
        t.strings.add(mp); // CHANGE HERE
        ds.save(t);
        t=ds.get(t);
        ds.ensureIndexes();
    }
}

e crie uma nova classe:
@Embedded
public class MapProxy {
    public Map<String,Object> m = new HashMap<String, Object>();

}

Eu marquei as alterações que fiz.

A estrutura que isso produz é assim:
{
    "_id" : "hi",
    "className" : "YOUR CLASS NAME HERE",
    "strings" : 
                [ { 
                     "m" : 
                            { 
                                "Hi" : "1" , 
                                "Hi2" : 2
                            } 
                } ]
}