MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

MongoDB-Punti di escape '.' in chiave mappa]

Quando usi Spring Data MongoDB ottieni un'istanza di:org.springframework.data.mongodb.core.convert.MappingMongoConverter che ha mapKeyDotReplacement impostato su null per impostazione predefinita:ecco perché stai ricevendo un'eccezione.

Devi creare la tua istanza di org.springframework.data.mongodb.core.convert.MappingMongoConverter o semplicemente modifica l'istanza esistente usando il suo metodo setter del provider:

/**
 * Configure the characters dots potentially contained in a {@link Map} shall be replaced with. By default we don't do
 * any translation but rather reject a {@link Map} with keys containing dots causing the conversion for the entire
 * object to fail. If further customization of the translation is needed, have a look at
 * {@link #potentiallyEscapeMapKey(String)} as well as {@link #potentiallyUnescapeMapKey(String)}.
 * 
 * @param mapKeyDotReplacement the mapKeyDotReplacement to set
 */
public void setMapKeyDotReplacement(String mapKeyDotReplacement) {
    this.mapKeyDotReplacement = mapKeyDotReplacement;
}

In MongoDB, il punto è sempre trattato come un carattere speciale, quindi evitarlo molto probabilmente ti farà risparmiare qualche altro mal di testa in futuro.

EDIT:per sovrascrivere MappingMongoConverter predefinito aggiungi la seguente dichiarazione di bean:

  @Bean
  public MappingMongoConverter mongoConverter(MongoDbFactory mongoFactory) throws Exception {
    DbRefResolver dbRefResolver = new DefaultDbRefResolver(mongoFactory);
    MappingMongoConverter mongoConverter = new MappingMongoConverter(dbRefResolver, mongoMappingContext);
    mongoConverter.setMapKeyDotReplacement(".");

    return mongoConverter;
  }