MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Morphia List>> return L'élément incorporé n'est pas un DBObject lors de l'opération de recherche

Morphia voit Map comme une référence DB à un autre document plutôt que de le voir comme une classe intégrée et de le traiter comme un document. La solution serait d'annoter la Map @Embedded, mais ce n'est pas possible car vous ne pouvez pas modifier la classe Map.

Il existe un moyen d'obtenir quelque chose de similaire à ce que vous essayez en créant une autre classe et en définissant la carte comme une propriété de cette classe et en l'annotant comme @Embedded.

Modifiez la 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();
    }
}

et créez une nouvelle classe :

@Embedded
public class MapProxy {
    public Map<String,Object> m = new HashMap<String, Object>();

}

J'ai marqué les modifications que j'ai apportées.

La structure que cela produit ressemble à ceci :

{
    "_id" : "hi",
    "className" : "YOUR CLASS NAME HERE",
    "strings" : 
                [ { 
                     "m" : 
                            { 
                                "Hi" : "1" , 
                                "Hi2" : 2
                            } 
                } ]
}