Redis
 sql >> Base de données >  >> NoSQL >> Redis

Redis - Comment configurer les conversions personnalisées

Testé avec spring-boot-starter-data-redis:2.0.4.RELEASE .

J'étais confronté à un problème où mon OffsetDateTime propriétés de mon @RedisHash l'entité n'était pas stockée lors de l'utilisation de CrudRepository .

Le problème était que Jsr310Converters n'a pas de convertisseur de OffsetDateTime .

Pour résoudre ce problème, j'ai créé un convertisseur de lecture :

@Component
@ReadingConverter
public class BytesToOffsetDateTimeConverter implements Converter<byte[], OffsetDateTime> {
    @Override
    public OffsetDateTime convert(final byte[] source) {
        return OffsetDateTime.parse(new String(source), DateTimeFormatter.ISO_OFFSET_DATE_TIME);
    }
}

et convertisseur d'écriture :

@Component
@WritingConverter
public class OffsetDateTimeToBytesConverter implements Converter<OffsetDateTime, byte[]> {
    @Override
    public byte[] convert(final OffsetDateTime source) {
        return source.format(DateTimeFormatter.ISO_OFFSET_DATE_TIME).getBytes();
    }
}

Et enregistré un RedisCustomConversions haricot dans la configuration :

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.core.convert.RedisCustomConversions;
import org.springframework.data.redis.repository.configuration.EnableRedisRepositories;

import java.util.Arrays;

@Configuration
@EnableRedisRepositories
public class RedisConfiguration {

    @Bean
    public RedisCustomConversions redisCustomConversions(OffsetDateTimeToBytesConverter offsetToBytes,
                                                         BytesToOffsetDateTimeConverter bytesToOffset) {
        return new RedisCustomConversions(Arrays.asList(offsetToBytes, bytesToOffset));
    }

}