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

Spring Data Mongo - Jak mapovat zděděné entity POJO?

Odpovím si na svou otázku. Jak je uvedeno v komentářích, řešením je použít Converter .

Zde je příklad toho, čeho jsem chtěl dosáhnout se svým modelem třídy:

Contact může být buď Person nebo Organisation .

Pokud používáte spring-data-mongodb MongoRepository k zápisu dat do databáze podle vašeho modelu entity, _class pole bude přidáno ke kořenům dokumentů a ke komplexním typům vlastností (viz tuto sekci ). Tato pole ukládají plně kvalifikovaný název třídy Java a umožňují jednoznačnost při mapování z dokumentu MongoDb na datový model Spring.

Pokud vaše aplikace pouze čte dokument z databáze (bez _class polí), musíte datům Spring sdělit, kterou třídu mají vytvořit instanci při mapování Contact . Spring-data vám umožňují přizpůsobit výchozí chování mapování typů pomocí Converter . Použití explicitního Converter přepsat výchozí mapování pro třídu . musíte explicitně zmapovat celou třídu. Zde je příklad mého ContactReadConverter :

@ReadingConverter
public class ContactReadConverter implements Converter<Document, Contact> {

    @Override
    public Contact convert(Document source) {
        if (source.get("firstName") == null) {
            Organisation organisation = new Organisation();
            I18n name = new I18n();
            name.setEn(source.get("name", Document.class).get("en", String.class));
            name.setFr(source.get("name", Document.class).get("fr", String.class));
            organisation.setName(name);
            organisation.setAcronym(source.get("acronym", String.class));
            organisation.setRole(source.get("role", String.class));
            return organisation;
        }
        Person person = new Person();
        person.setFirstName(source.get("firstName", String.class));
        person.setLastName(source.get("lastName", String.class));
        person.setRole(source.get("role", String.class));
        person.setEmail(source.get("email", String.class));
        person.setOrcId(source.get("orcId", String.class));
        if (source.get("organisation") != null) {
            Document sourceOrg = source.get("organisation", Document.class);
            Organisation organisation = new Organisation();
            organisation.setAcronym(sourceOrg.get("acronym", String.class));
            organisation.setRole(sourceOrg.get("role", String.class));
            if (sourceOrg.get("name") != null) {
                I18n name = new I18n();
                name.setFr(sourceOrg.get("name", Document.class).get("fr", String.class));
                name.setEn(sourceOrg.get("name", Document.class).get("en", String.class));
                organisation.setName(name);
            }
            person.setOrganisation(organisation);
        }
        return person;
    }
}

Poté je třeba zaregistrovat nově definované převodníky:

@Configuration
public class DataportalApplicationConfig extends AbstractMongoConfiguration {
    @Value("${spring.data.mongodb.uri}")
    private String uri;
    @Value("${spring.data.mongodb.database}")
    private String database;
    @Override
    public MongoClient mongoClient() {
        return new MongoClient(new MongoClientURI(uri));
    }
    @Override
    protected String getDatabaseName() {
        return database;
    }    
    @Bean
    @Override
    public MongoCustomConversions customConversions() {
        List<Converter<?, ?>> converterList = new ArrayList<>();
        converterList.add(new ContactReadConverter());
        return new MongoCustomConversions(converterList);
    }
}

Doufám, že to pomůže.




  1. Vezmeme součet sloupce v MongoDB

  2. Jaký je rozdíl mezi safe:true a safe:false ve spojení s mongoskinem? a jak to použít?

  3. Jak uložit výsledek dotazu (jeden dokument) do proměnné?

  4. V MongoDB se sloučí 2 dokumenty