[go-redis] go操作redis数据库[亲测有效]

[go-redis] go操作redis数据库[亲测有效]go,redis,go-redis/redis,NoSQL

[go-redis] go操作redis数据库

先上命令速查网站,菜鸟yyds
https://www.runoob.com/redis/redis-strings.html
操作redis的包是go-redis/redis
官方文档 https://redis.uptrace.dev/guide/
github https://github.com/go-redis/redis

创建项目
创建test文件夹
创建 Redis_test.go 文件
直接上代码,代码解释全写在注释里

package test

import (
	"context"
	"encoding/json"
	"fmt"
	"github.com/go-redis/redis/v8"
	"testing"
	"time"
)


var ctx = context.Background()

var rdb *redis.Client

func init() {
	rdb = redis.NewClient(&redis.Options{
		//	端口需要改,这里是docker的端口
		Addr:	  "localhost:49153",
		Password: "redispw", // no password set
		DB:		  0,  // use default DB
		PoolSize:15,
		MinIdleConns: 10, //在启动阶段创建指定数量的Idle连接,并长期维持idle状态的连接数不少于指定数量;。
		//超时
		//DialTimeout:  5 * time.Second, //连接建立超时时间,默认5秒。
		//ReadTimeout:  3 * time.Second, //读超时,默认3秒, -1表示取消读超时
		//WriteTimeout: 3 * time.Second, //写超时,默认等于读超时
		//PoolTimeout:  4 * time.Second, //当所有连接都处在繁忙状态时,客户端等待可用连接的最大等待时长,默认为读超时+1秒。
	})
}


//	基础使用
func Test_Base(t *testing.T) {
	//	添加key
	//0表示没有过期时间
	rdb.Set(ctx, "testKey", "xxx", 0)

	//	获取值
	val, err := rdb.Get(ctx, "testKey").Result()
	if err != nil {
		fmt.Println("错误", err)
	}
	fmt.Println("值:", val)

	//	设置key过期时间 成功true
	rdb.Expire(ctx, "testKey", time.Second*60)

	//	存在返回1
	rdb.Exists(ctx, "testKey")

	//	key不存在时设置值
	rdb.SetNX(ctx, "unkey", "val", 0)

	rdb.Set(ctx, "testKey2", "xxx", 0)
	//	删除key 可删除多个
	rdb.Del(ctx, "testKey2", "testKey")

}

//	字符串
func Test_String(t *testing.T) {
	//	设置值
	rdb.Set(ctx, "strKey", 100, 0)
	rdb.Set(ctx, "straey", 100, 0)

	//	key自增1
	rdb.Incr(ctx, "strKey")
	//	增加 66
	rdb.IncrBy(ctx, "straey", 66)

	//	-1
	rdb.Decr(ctx, "straey")
	//	-5
	rdb.DecrBy(ctx, "straey", 5)

	//	过期时间
	rdb.TTL(ctx, "strKey")
	//	str*ey		: *为任意字符串
	//	str[kKac]ey : 匹配[] 内的单个字符 strkey,strKey,straey,strcey
	//	str?ey		: ? 任意单个字符
	//	扫描key
	iter := rdb.Scan(ctx, 0, "str?ey", 0).Iterator()
	for iter.Next(ctx) {
		fmt.Println("keys", iter.Val(), ": val", rdb.Get(ctx, iter.Val()).Val())
	}
	if err := iter.Err(); err != nil {
		panic(err)
	}

}

//	哈希
func Test_Hash(t *testing.T) {
	rdb.HMSet(ctx,"hkey1","name","shushan","age",99,"b",true)

	//	以结构体存入 注意redis tag
	type User struct {
		Name string `json:"name,omitempty" redis:"name"`
		Age  int    `json:"age,omitempty" redis:"age"`
		B    bool   `json:"b,omitempty" redis:"b"`
		//...
	}
	user1 := User{
		Name: "shushan2",
		Age:  55,
		B:    true,
	}
	//	结构体序列化反序列化map 你也可以用其他包进行转化为map,但是注意转化后的键名大小写问题
	m := make(map[string]interface{})
	buf,_ := json.Marshal(user1)
	_ = json.Unmarshal(buf,&m)

	//	存入
	rdb.HSet(ctx, "user4", m)

	//	取出绑定到结构体 map也行
	var user User
	rdb.HGetAll(ctx,"user4").Scan(&user)
	fmt.Printf(" %#v 
 ",user)
	//	test.User{Name:"shushan2", Age:55, B:true}

	//	获取key下的所有值   *匹配方式与string的所有原理一样
	iter := rdb.HScan(ctx,"user4",0,"*",0).Iterator()
	for iter.Next(ctx) {
		fmt.Println("keys", iter.Val())
	}
	if err := iter.Err(); err != nil {
		panic(err)
	}
}


//	列表
func Test_List(t *testing.T) {
	//	添加
	rdb.LPush(ctx,"listKey1",111,222,333,444)
	rdb.RPush(ctx,"listKey1",5555)
	//	不存在不添加
	rdb.LPushX(ctx,"unlistKey",111)

	var intf []int
	//	根据索引获取 绑定到数组
	rdb.LRange(ctx,"listKey1",0,10).ScanSlice(&intf)
	fmt.Println(intf)

	var i int
	//	弹出
	rdb.LPop(ctx,"listKey1").Scan(&i)
	fmt.Println(i)

	//....

}



//	集合
func Test_Set(t *testing.T) {
	//	添加
	rdb.SAdd(ctx,"setKey1","m1","onlyk1")
	rdb.SAdd(ctx,"setKey2","m2","xca")


	sl,_:= rdb.SDiff(ctx,"setKey1","setKey2").Result()
	fmt.Println(sl)
	// onlyk1,m1

	//随机移除
	var val string
	rdb.SPop(ctx,"setKey1").Scan(&val)
	fmt.Println(val)

	// .....
}

//	管道
func Test_Pipe(t *testing.T) {
	// 	官方描述
	// 	Redis 管道允许客户端命令服务器通过执行任务而通过执行任务来提高您的性能。
	//	在管道中,像命令命令一样将编写 + 使用命令来执行任务,并将其用于执行任务,执行任务不是一个地执行100个命令。
	//	理解为命令就像石头,一次运送一个石头
	//	使用管道等于 用车装石头  Exec 时就运送过去
	pipe := rdb.Pipeline()

	incr := pipe.Set(ctx, "pip_test","bt",0)
	pipe.Expire(ctx, "pip_test", time.Hour)

	//	提交
	cmds, err := pipe.Exec(ctx)
	if err != nil {
		fmt.Println(err)
	}
	for _, cmd := range cmds {
		fmt.Println(cmd.String())
	}

	// 该值得Exec提交后有效
	fmt.Println(incr.Val())
}


其他操作都可以查看go-redis的源码或者直接打出rdb.命令,go-redis 的函数命名方式和redis的命令是差不多的

The end

原文地址:https://www.cnblogs.com/xushushan/archive/2022/07/20/16498266.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/4996.html

(0)
上一篇 2023-05-27
下一篇 2023-05-27

相关推荐

  • MYSQL数据库原理与应用贾晶教材答案_SQL数据库

    MYSQL数据库原理与应用贾晶教材答案_SQL数据库数据库增删改查操作,重点总结了SELECT语句

    2023-05-29
    150
  • Python工程师

    Python工程师Python是一种高级编程语言,具有简单、易读、易学的特点,同时可以应用于开发web应用、爬虫、数据分析、人工智能等多个领域,在工业界和学术界都有较广泛的应用。因此,Python工程师也成为了IT行业中的热门职位之一。

    2024-05-09
    74
  • 用Python自加一

    用Python自加一在Python中,我们可以通过给列表添加一个新元素来实现列表加一个数。首先,我们需要定义一个列表:

    2024-05-15
    78
  • 大数据Hadoop之——Spark on Hive 和 Hive on Spark的区别与实现「建议收藏」

    大数据Hadoop之——Spark on Hive 和 Hive on Spark的区别与实现「建议收藏」一、Spark on Hive 和 Hive on Spark的区别 1)Spark on Hive Spark on Hive 是Hive只作为存储角色,Spark负责sql解析优化,执行。这里可以

    2023-05-14
    138
  • 用IDEA创建Python项目

    用IDEA创建Python项目Python是一种高级语言,常被用作脚本语言和Web开发。随着Python语言的广泛应用,越来越多的开发者开始学习Python语言。在使用Python进行开发时,很多人习惯于使用某些IDE,比如:PyCharm、Visual Studio Code等等。而本文将从另一个角度,介绍如何使用IntelliJ IDEA开发Python项目。

    2024-08-15
    29
  • 如何安装Tesseract

    如何安装TesseractTesseract是一个由HP实验室开发的免费OCR引擎。它最初发布于1985年,但直到2005年才成为开源软件。自那时以来,Tesseract已经成长为一款功能强大的OCR引擎,并且已被许多人在各种应用程序中使用。

    2024-08-28
    24
  • 20200617学习笔记[通俗易懂]

    20200617学习笔记[通俗易懂]基数 一个索引上不同的值的个数,我们称之为“基数”(cardinality)。也就是说,这个基数越大,索引的区分度越好 我们可以使用 show index 方法,看到一个索引的基数 MySQL 是怎…

    2023-03-12
    154
  • Navicat 连接 MySQL 8.0.2 出现 2059 错误「建议收藏」

    Navicat 连接 MySQL 8.0.2 出现 2059 错误「建议收藏」原因:MySQL8之前的版本中加密规则是mysql_native_password,而在MySQL8之后,加密规则是caching_sha2_password解决:mysql-uroot-pusem…

    2023-02-22
    163

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注