怎么用redigo操作redis?

前言

redigo能用于go操作redis,用于实现Redis数据库的基本操作,支持Redis的所有命令

redigo使用

redigo依赖安装

使用以下命令安装redigo依赖,以前使用的是这个命令,但是这个依赖过时了,使用最下面的安装依赖

 

arduino

代码解读

复制代码

go get github.com/garyburd/redigo/redis

redigo最新依赖

 

arduino

代码解读

复制代码

go get github.com/gomodule/redigo/redis

redigo使用

说明: redigo使用Do()方法操作redis所有的api

redigo连接redis
 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c, err := redis.Dial("tcp", "localhost:6379") if err != nil { fmt.Println("redis连接失败:", err) return } a, err1 := c.Do("ping") if err1 != nil { fmt.Println("连接失败:", err1) return } fmt.Println(a) defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) }

输出结果为:

image.png

备注:

如果redis有密码的话,使用以下连接

 

go

代码解读

复制代码

c, err := redis.Dial("tcp", "localhost:6379", redis.DialPassword("123456")) if err != nil { fmt.Println("redis连接失败:", err) return }

redigo操作字符串

redis字符串的命令为: 设置数据为:

 

sql

代码解读

复制代码

SET a1 a1

获取数据为

 

sql

代码解读

复制代码

GET a1

redigo操作字符串

 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c, err := redis.Dial("tcp", "localhost:6379") if err != nil { fmt.Println("redis连接失败:", err) return } _, err1 := c.Do("set", "a1", "a1") if err1 != nil { fmt.Println("设置数据失败:", err1) return } val, err2 := c.Do("get", "a1") if err != nil { fmt.Println("获取字符串失败:", err2) return } strVal, _ := redis.String(val, nil) fmt.Println("数据为: ", strVal) defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) }

设置键值过期时间示例
 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" "time" ) func main() { c, err := redis.Dial("tcp", "localhost:6379") if err != nil { fmt.Println("redis连接失败:", err) return } _, err1 := c.Do("set", "hello1", "test", "EX", "5") if err1 != nil { fmt.Println("设置过期时间失败:", err1) return } time.Sleep(time.Second * 6) valWithEx, _ := redis.String(c.Do("get", "hello1")) fmt.Println("获取值为:", valWithEx) defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) }

redigo判断键值是否存在
 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c, err := redis.Dial("tcp", "localhost:6379") if err != nil { fmt.Println("redis连接失败:", err) return } // 是否存在指定key exists, _ := c.Do("exists", "hello10") flag, _ := redis.Int(exists, nil) fmt.Println("hello10是否存在:", flag == 1) defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) }

redigo操作List

将一个或多个值插入到列表头部

 

代码解读

复制代码

LPUSH list1 aa

在列表中添加一个或多个值到列表尾部

 

kotlin

代码解读

复制代码

rpush list val

获取列表指定范围内的元素

 

代码解读

复制代码

LRANGE runoobkey 0 10

redigo操作List

 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c, err := redis.Dial("tcp", "localhost:6379") if err != nil { fmt.Println("redis连接失败:", err) return } c.Do("lpush", "list1", "l1") c.Do("rpush", "list1", "l3") list, _ := c.Do("lrange", "list1", "0", "100") l, _ := redis.Values(list, nil) for _, val := range l { fmt.Println(string(val.([]byte))) } defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) }

redigo操作Set

往set1添加数据

 

代码解读

复制代码

SADD set1 redis aaa

获取set1数据

 

代码解读

复制代码

SMEMBERS set1

redigo操作set

 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c, err := redis.Dial("tcp", "localhost:6379") if err != nil { fmt.Println("redis连接失败:", err) return } c.Do("sadd", "set1", "a1", "a2") list, _ := c.Do("smembers", "set1") l, _ := redis.Values(list, nil) for _, val := range l { fmt.Println(string(val.([]byte))) } defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) }

redigo操作hash

redis操作hash,将哈希表 key 中的字段 field 的值设为value

 

markdown

代码解读

复制代码

HSET key field value

获取在哈希表中指定 key 的所有字段和值

 

vbnet

代码解读

复制代码

HGETALL key

redigo操作hash

 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c, err := redis.Dial("tcp", "localhost:6379") if err != nil { fmt.Println("redis连接失败:", err) return } _, err = c.Do("HSet", "books", "abc", 10) if err != nil { fmt.Println(err) return } r, err := redis.Int(c.Do("HGet", "books", "abc")) if err != nil { fmt.Println("get abc failed,", err) return } fmt.Println(r) defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) }

redigo操作zset

向有序集合添加一个或多个成员,或者更新已存在成员的分数

 

css

代码解读

复制代码

ZADD key score1 member1 [score2 member2]

通过分数返回有序集合指定区间内的成员

 

arduino

代码解读

复制代码

ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]

redigo操作zset

 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" ) func main() { c, err := redis.Dial("tcp", "localhost:6379") if err != nil { fmt.Println("redis连接失败:", err) return } _, err = c.Do("zadd", "runoobkey", 1, "redis") if err != nil { fmt.Println(err) return } r, err := c.Do("ZRANGE", "runoobkey", 0, 10, "WITHSCORES") if err != nil { fmt.Println("get abc failed,", err) return } l, _ := redis.Values(r, nil) for _, val := range l { fmt.Println(string(val.([]byte))) } defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) }

redigo使用连接池
 

go

代码解读

复制代码

package main import ( "fmt" "github.com/gomodule/redigo/redis" ) var pool *redis.Pool func init() { pool = &redis.Pool{ MaxIdle: 8, MaxActive: 0, IdleTimeout: 300, Dial: func() (redis.Conn, error) { return redis.Dial("tcp", "localhost:6379") }, } } func main() { c := pool.Get() defer func(c redis.Conn) { err := c.Close() if err != nil { } }(c) _, err := c.Do("set", "hello5", "aaa") if err != nil { fmt.Println(err) return } r, err := redis.Strings(c.Do("get", "hello5")) if err != nil { fmt.Println("获取键值失败:", err) return } fmt.Println(r) err1 := pool.Close() if err1 != nil { return } }

总结

redigo的包操作较为简练,一般为操作redis的命令,至于在开发中的技术选型,看个人习惯以及是否能提高自己开发效率而定,但是redigo自身不支持集群,这点需要注意,要支持集群,需要引入其他包

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值