MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Spring Data Mongo - Jak zmapować odziedziczone encje POJO?

Odpowiem na własne pytanie. Jak wspomniano w komentarzach, rozwiązaniem jest użycie Converter .

Oto przykład tego, co chciałem osiągnąć dzięki mojemu modelowi klasy:

Contact może być Person lub Organisation .

Jeśli używasz spring-data-mongodb MongoRepository aby zapisać dane w Twojej bazie danych zgodnie z Twoim modelem encji, _class pole zostanie dodane do katalogu głównego dokumentu i do złożonych typów właściwości (zobacz tę sekcję ). Pola te przechowują w pełni kwalifikowaną nazwę klasy Java i umożliwiają ujednoznacznienie podczas mapowania z dokumentu MongoDb na model danych Spring.

Jeśli Twoja aplikacja właśnie odczytuje dokument z bazy danych (bez _class pola), musisz powiedzieć Spring data, którą klasę utworzyć podczas mapowania Contact . Spring-data pozwala dostosować domyślne zachowanie mapowania typów za pomocą Converter . Używanie jawnego Converter zastąp domyślne mapowanie dla klasy . musisz wyraźnie zmapować całą swoją klasę. Oto przykład mojego 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;
    }
}

Następnie należy zarejestrować nowo zdefiniowane konwertery:

@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);
    }
}

Mam nadzieję, że to pomoże.




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. ImportError:brak modułu o nazwie parse

  2. PyMongo max_time_ms

  3. Maksymalny rozmiar stosu wywołań przekroczony przy wstawianiu 10000 dokumentów

  4. Łączona nazwa kolekcji MongoDB

  5. Jak zmienić wszystkie elementy tablicy w dokumencie mongodb na określoną wartość?