目录取值方法不推荐推荐DoVar示例ReceiveVar示例HashSet示例小技巧总结上一篇文章为大家介绍了 GoFrame GCache使用实践 | 缓存控制 淘汰策略 ,得到了大家积极的反馈。 后续几篇文章再接再厉
上一篇文章为大家介绍了 GoFrame GCache使用实践 | 缓存控制 淘汰策略 ,得到了大家积极的反馈。
后续几篇文章再接再厉,仍然为大家介绍GoFrame框架缓存相关的知识点,以及自己项目使用中的一些总结思考,GoFrame框架下文简称gf。
今天重点为大家介绍:GoFrame gredis 如何优雅的取值和类型转换
通过客户端方法Do/Receive获取的数据都是二进制形式[]byte的,需要开发者手动进行数据转换。 不推荐大家这么取值。
gRedis模块也提供了DoVar/ReceiveVar方法,用以获取可供方便转换的gvar.Var通用变量结果。
通过gvar.Var的强大转换功能可以转换为任意的数据类型,如基本数据类型:Int,String,Strings,或者结构体Struct等等。
package main
import (
"fmt"
"GitHub.com/gogf/gf/frame/g"
)
func main() {
conn := g.Redis().Conn()
defer conn.Close()
conn.Do("SET", "key", "value")
v, _ := conn.DoVar("GET", "key")
fmt.Println(v.String()) //打印结果:value
}
package main
import (
"fmt"
"github.com/gogf/gf/frame/g"
)
func main() {
conn := g.Redis().Conn()
defer conn.Close()
_, err := conn.Do("SUBSCRIBE", "channel")
if err != nil {
panic(err)
}
for {
reply, err := conn.ReceiveVar()
if err != nil {
panic(err)
}
fmt.Println(reply.Strings())
}
}
执行后,程序将阻塞等待获取数据。
另外打开一个终端通过redis-cli命令进入Redis Server,发布一条消息:
$ redis-cli
127.0.0.1:6379> publish channel gf-test
(integer) 1
127.0.0.1:6379>
随后程序终端立即打印出从Redis Server获取的数据:
[message channel gf-test]
如果我们习惯使用Redis的HashSet数据结构,我们可以非常方便地将Redis中的HashSet获取并转换为golang中的Map数据类型。
package main
import (
"fmt"
"github.com/gogf/gf/container/gvar"
"github.com/gogf/gf/frame/g"
)
func main() {
var (
err error
result *gvar.Var
key = "test"
)
_, err = g.Redis().Do("HSET", key, "id", 1)
if err != nil {
panic(err)
}
_, err = g.Redis().Do("HSET", key, "name", "王中阳")
if err != nil {
panic(err)
}
result, err = g.Redis().DoVar("HGETALL", key)
if err != nil {
panic(err)
}
fmt.Println(result.Map()) //打印结果:map[id:1 name:王中阳]
}
通过这篇文章我们了解到:可以使用DoVar和ReceiveVar获取可供方便转换的gvar.Var通用结果,通过gvar.Var的强大转换功能可以转换为任意的数据类型。
另外了解到一个小技巧:如果使用Redis的HashSet数据结构,我们可以非常方便地将Redis中的HashSet获取并转换为Golang中的Map数据类型。
更多关于GoFrame gredis取值类型转换的资料请关注我们其它相关文章!
--结束END--
本文标题: GoFrame框架gredis优雅的取值和类型转换
本文链接: https://lsjlt.com/news/32947.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0