MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

MongoDB-Escape-Punkte '.' im Kartenschlüssel]

Wenn Sie Spring Data MongoDB verwenden, erhalten Sie eine Instanz von:org.springframework.data.mongodb.core.convert.MappingMongoConverter das hat mapKeyDotReplacement standardmäßig auf null gesetzt - deshalb erhalten Sie eine Ausnahme.

Sie müssen entweder Ihre eigene Instanz von org.springframework.data.mongodb.core.convert.MappingMongoConverter erstellen oder ändern Sie einfach die vorhandene Instanz mit der Provider-Setter-Methode:

/**
 * 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 wird der Punkt immer als Sonderzeichen behandelt, sodass Sie sich in Zukunft wahrscheinlich einige weitere Kopfschmerzen ersparen werden, wenn Sie ihn vermeiden.

BEARBEITEN:Um den Standard MappingMongoConverter zu überschreiben fügen Sie die folgende Bean-Deklaration hinzu:

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

    return mongoConverter;
  }