Como o Redis não tem nenhum conceito de valores de tempo, não faria sentido para um driver genérico como o redigo realizar alguma conversão automática entre o
time.Time
builin tipo e uma matriz de bytes arbitrária. Como tal, cabe ao programador decidir como realizar essa conversão. Por exemplo, supondo que você tenha um tipo "Pessoa" definido como tal, incluindo um
created_at
timestamp formatado como RFC3339 (uma forma de ISO 8601), você pode definir um tipo de "Timestamp" personalizado com um método "RedisScan" da seguinte forma:type Timestamp time.Time
type Person struct {
Id int `redis:"id"`
Name string `redis:"name"`
CreatedAt Timestamp `redis:"created_at"`
}
func (t *Timestamp) RedisScan(x interface{}) error {
bs, ok := x.([]byte)
if !ok {
return fmt.Errorf("expected []byte, got %T", x)
}
tt, err := time.Parse(time.RFC3339, string(bs))
if err != nil {
return err
}
*t = Timestamp(tt)
return nil
}
// ...
response, err := redis.Values(conn.Do("HGETALL", "person:1"))
if err != nil {
panic(err)
}
var p Person
err = redis.ScanStruct(response, &p)
if err != nil {
panic(err)
}
log.Printf("OK: p=%v", p)