STRHM
1.0.0
Artigo de introdução
A entidade de exemplo será uma classe Book, que possui alguns campos básicos.
public class Book
{
public int Id { get; set; }
public int? Rating { get; set; }
public DateTime PublishedOn { get; set; }
[SerializableRedisProperty]
public List<Author> Authors { get; set; }
}
Isso mesmo, você notou um atributo personalizado. Este atributo é responsável pela serialização de uma propriedade específica quando está sendo definida no hash Redis como um valor.
O repositório de livros herda de BaseRedisHashSetRepository, pois expõe a funcionalidade necessária mais comum e a conexão com o banco de dados, caso você queira estender a funcionalidade do próprio repositório de livros.
public class BookRepository : BaseRedisHashSetRepository<Book>
{
public BookRepository(IRedisConnection redisConnection, IStronglyTypedRedisSerializer serializer, RedisHashSetOptions configurationOptions)
: base(redisConnection, serializer, configurationOptions)
{
}
}
Parâmetros do construtor:
Exemplos de obtenção de valores:
// Check if value is set on property
if (updatedBook.HasValue(b => b.Rating))
// Get values
updatedBook.Get<IEnumerable<Author>>(b => b.Authors)
updatedBook.Get<int?>(b => b.Rating)
ou
var book = await _bookRepository.GetAsync(book.Id.ToString());
Exemplos de configuração de valores:
await _bookRepository.SaveAsync(book.Id.ToString(), book);
ou
await _bookRepository.HashSetAsync(book.Id.ToString(), new StronglyTypedDictionary<Book>(new StronglyTypedRedisNewtonsoftSerializer())
{
{ b => b.Rating, 10 },
{ b => b.Authors, new List<Author>()},
{ b => b.PublishedOn, DateTime.Now }
});