sql >> Databáze >  >> NoSQL >> MongoDB

Morphia List>> return Embedded element není DBObject při operaci hledání

Morphia vidí Mapu jako DB odkaz na jiný dokument, spíše než aby ji viděla jako vloženou třídu a zacházela s ní jako s dokumentem. Řešením by bylo anotovat Mapu @Embedded, ale to není možné, protože třídu Map nemůžete upravit.

Existuje způsob, jak dosáhnout něčeho podobného, ​​co se pokoušíte, vytvořením další třídy a definováním Map jako vlastnosti této třídy a anotací jako @Embedded.

Změňte třídu 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();
    }
}

a vytvořte novou třídu:

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

}

Označil jsem změny, které jsem provedl.

Struktura, kterou to vytváří, je tato:

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


  1. MongoDB $setUnion

  2. Je možné v Mongu efektivně třídit, seskupovat a omezovat pomocí potrubí?

  3. .get() vyžaduje funkce zpětného volání, ale má [object Undefined]

  4. Kompozitní klíč MongoDB