Redis数据库与GO完结篇:redis操作总结与GO使用redis

一、redis操作总结

由于写redis命令的时候有提示符,所以下表只给出命令名称

数据类型 操作 简介
字符串 GET, SET, MGET, MSET, SETEX,DEL 最基本的数据类型,存储任意二进制数据,支持简单操作和原子计数。适合存储重复数据。
哈希 HSET, HGET, HDEL, HMSET, HMGET, HEXISTS,HGETALL,HLEN 键值对集合,适合存储对象,支持字段操作。可存储重复字段。
列表 LPUSH, RPUSH, LPOP, RPOP, LRANGE, LSET, LREM 有序字符串集合,支持双向操作,适合实现消息队列,允许重复元素。
集合 SADD, SREM, SMEMBERS, SISMEMBER 无序唯一元素集合,不允许重复,支持集合运算,适合实现标签和用户兴趣。
有序集合 ZADD, ZREM, ZRANGE 带分数的有序集合,不允许重复,支持范围查询和排序,适合实现排行榜等。

二、GO连接redis

go-redis 支持 2 个最新的 go 版本且依赖Go modules,如果你还没有 go mod,你需要首先初始化:

go 复制代码
go mod init github.com/my/repo

安装 go-redis/v9 (支持所有的 redis 版本):

go 复制代码
go get github.com/redis/go-redis/v9

参考链接:GO REDIS快速入门

然后导包即可使用redis:import "github.com/redis/go-redis/v9"

GO链接redis分为以下几步:

1.配置链接信息

go 复制代码
opts := redis.Options{
	Addr:     "localhost:6379", // Redis 服务器地址和端口
	Password: "",               // Redis 密码,默认为空
	DB:       0,                // Redis 数据库编号,默认为 0
}

2.创建客户端

go 复制代码
rdb := redis.NewClient(&opts)

3.创建上下文

go 复制代码
ctx := context.Background()

4.测试连接

go 复制代码
_, err := rdb.Ping(ctx).Result()
if err != nil {
	fmt.Println("连接 Redis 失败!")
	return
}
fmt.Println("连接 Redis 成功!")

操作2-4都已被本人封装在一个函数中:

go 复制代码
// 创建 Redis 客户端并返回客户端和上下文
func ConnectRedis(opts *redis.Options) (*redis.Client, context.Context, error) {
	// 创建 Redis 客户端
	rdb := redis.NewClient(opts)

	// 创建上下文
	ctx := context.Background()

	// 测试连接
	_, err := rdb.Ping(ctx).Result()
	if err != nil {
		fmt.Println("连接 Redis 失败!")
		return nil, nil, err
	}
	fmt.Println("连接 Redis 成功!")

	return rdb, ctx, nil
}

本人已在自定义包中定义此函数,这样,用户无需每次手动测试链接。自定义包已部署在gitee上,读者可通过go get+本人的项目地址获取,项目地址:my_gopkg。使用前建议阅读README。

三、GO操作redis

go-redis封装的函数名和redis语句是一样的,传参除了传入上下文变量也是一样的,只是调用函数时多了Err()和Result()。Result()用于获取 Redis 命令的返回值。Err()用于获取命令执行的错误信息。

数据类型以哈希表为例,GO链接,操作redis的完整代码如下:

go 复制代码
package main

import (
	"context"
	"fmt"
	"time"

	"github.com/redis/go-redis/v9"
)

// ConnectRedis 创建 Redis 客户端并返回客户端和上下文
func ConnectRedis(opts *redis.Options) (*redis.Client, context.Context, error) {
	// 创建 Redis 客户端
	rdb := redis.NewClient(opts)

	// 创建上下文
	ctx := context.Background()

	// 测试连接
	_, err := rdb.Ping(ctx).Result()
	if err != nil {
		fmt.Println("连接 Redis 失败!")
		return nil, nil, err
	}
	fmt.Println("连接 Redis 成功!")

	return rdb, ctx, nil
}
func main() {
	// 配置链接信息
	opts := redis.Options{
		Addr:     "localhost:6379", // Redis 服务器地址和端口
		Password: "",               // Redis 密码,默认为空
		DB:       0,                // Redis 数据库编号,默认为 0
	}
	rdb, ctx, err := ConnectRedis(&opts)
	if err != nil {
		return
	}
	// 创建用户
	err = rdb.HSet(ctx, "myhash", "name", "张三", "age", 30).Err()
	if err != nil {
		fmt.Println("创建用户失败:", err)
		return
	}
	fmt.Println("用户创建成功")

	// 获取用户信息
	userInfo, err := rdb.HGetAll(ctx, "myhash").Result()
	if err != nil {
		fmt.Println("获取用户信息失败:", err)
		return
	}
	fmt.Println("用户信息:", userInfo)

	// 更新用户信息
	err = rdb.HSet(ctx, "myhash", "name", "李四", "age", 25).Err()
	if err != nil {
		fmt.Println("更新用户信息失败:", err)
		return
	}
	fmt.Println("用户信息更新成功")

	// 再次获取用户信息以查看更新效果
	updatedInfo, err := rdb.HGetAll(ctx, "myhash").Result()
	if err != nil {
		fmt.Println("获取更新后的用户信息失败:", err)
		return
	}
	fmt.Println("更新后的用户信息:", updatedInfo)

	// 设置键的过期时间为5秒
	err = rdb.Expire(ctx, "myhash", 5*time.Second).Err()
	if err != nil {
		fmt.Println("设置过期时间失败:", err)
		return
	}
	fmt.Println("设置过期时间成功")

	// 等待6秒
	time.Sleep(6 * time.Second)

	// 再次尝试获取哈希值(预期为空,因为键已过期)
	result, err := rdb.HGetAll(ctx, "myhash").Result()
	if err != nil {
		fmt.Println("获取用户信息失败:", err)
		return
	}
	if len(result) == 0 {
		fmt.Println("键已过期,无法获取用户信息")
	} else {
		fmt.Println("用户信息:", result)
	}

	// 删除用户信息
	err = rdb.Del(ctx, "myhash").Err()
	if err != nil {
		fmt.Println("删除用户信息失败:", err)
		return
	}
	fmt.Println("用户信息删除成功")
}
相关推荐
逻极15 分钟前
Redis Queue (RQ) 核心原理:轻量任务队列的设计与实践(一句话讲透核心本质)
数据库·redis·bootstrap
q***518928 分钟前
ubuntu 安装 Redis
linux·redis·ubuntu
2401_8370885036 分钟前
Redisson的锁重试和WatchDog机制
redis
q***318337 分钟前
Window下Redis的安装和部署详细图文教程(Redis的安装和可视化工具的使用)
数据库·redis·缓存
大锦终1 小时前
【MySQL】基本查询
数据库·mysql
last_zhiyin1 小时前
Oracle sql tuning guide 翻译 Part 6-5 --- Hint使用报告的操作方法和例子
数据库·sql·oracle·sql tunning
Rysxt_1 小时前
Spring Boot SPI 教程
java·数据库·sql
避避风港2 小时前
MySQL 从入门到实战
数据库·mysql
s***4532 小时前
MSSQL2022的一个错误:未在本地计算机上注册“Microsoft.ACE.OLEDB.16.0”提供程序
数据库·microsoft
梁bk2 小时前
Redis 多级缓存架构学习笔记
redis·缓存·架构