go学习redis的学习与使用

文章目录

    • 一、redis的学习与使用
      • 1.Redis的基本介绍
      • 2.Redis的安装下载安装包即可
      • 3.Redis的基本使用
        • 1)Redis的启动:
        • 2)Redis的操作的三种方式
        • 3)说明:Redis安装好后,默认有16个数据库,初始默认使用0号库,编号0...15
      • 4.Redis的五大数据类型和CRUD操作
        • 1)Redis的五大数据类型是:**String(字符串)**、**Hash(哈希)**、**List(列表)**、**Set(集合)**和**zset(sorted set :有序集合)**
        • 2)String
        • 3)Hash
        • 4)List
        • 5)Set
    • 二、go操作redis
      • 1、安装第三方开源的redis库
      • 2、使用go语言开始进行操作
        • 1)操作string
        • 2)操作hash
        • 3)批量操作Set/Get数据
        • 4)给数据设置有效时间
        • 5)课堂练习
        • 6)Redis连接池

一、redis的学习与使用

1.Redis的基本介绍

1).Redis是NoSQL数据库,不是传统的关系型数据库

官网: http://redis.io/ 和http://www.redis.cn/

2).Redis:REmote DIctionary Server(远程字典服务器),Redis的性能非常高,单机可以达到15W gps.通常适合做缓存,也可以持久化

3)是完全开源免费的,高性能的(key/value)分布式内存数据库,基于内存运行并支持持久化Nosql数据库,是最热门的NoSql数据库之一,也称为数据结构服务器

2.Redis的安装下载安装包即可

网址:https://github.com/tporadowski/redis/releases

下载好后的目录结构,其中有两个是redis的关键文件

redis客户端文件:redis-cli.exe

redis服务器文件:redis-server.exe

在这里插入图片描述

redis结构示意图

在这里插入图片描述

3.Redis的基本使用

1)Redis的启动:

启动Redis的服务器端程序(redis-server.exe),直接双击即可运行

在这里插入图片描述

2)Redis的操作的三种方式

在这里插入图片描述

说明:
1)使用telnet操作Redis
2)使用redis-cli.exe操作Redis,双击即可进入客户端
3)Golang操作redis

redis基本指令

http://redisdoc.com(已失效)

在这里插入图片描述

在这里插入图片描述

3)说明:Redis安装好后,默认有16个数据库,初始默认使用0号库,编号0…15

-1.添加key-val [set]

-2.查看当前redis的所有key [key * 获取key对应的值[get key]

-3.切换redis数据库[select index]

-4.如何查看当前数据库的key-val数量[dbsize]

在这里插入图片描述

-5.清空当前数据库的key-val和清空所有数据库的key -val[flush db flushall]

4.Redis的五大数据类型和CRUD操作

1)Redis的五大数据类型是:String(字符串)Hash(哈希)List(列表)Set(集合)zset(sorted set :有序集合)
2)String

(字符串)-介绍

-1.string是redis的基本类型,一个key对应一个value

-2.string是类型是二进制安全的。除普通的字符串外,也可以存放图片数据。

-3.redis中字符串value最大值是512M

举例,存放一个地址信息:

address北京天安门

说明:

key :address

value : 北京天安门

127.0.0.1:6379> set address beijing
OK
127.0.0.1:6379> get address
"beijing"
127.0.0.1:6379>

-4.String(字符串)-CRUD

举例说明Redis的String字符串的CRUD操作

set如果存在就相当于修改,不存在就是添加 /get/del

127.0.0.1:6379> del address
(integer) 1
127.0.0.1:6379> get address
(nil)
127.0.0.1:6379>

-5.String(字符串)-使用细节和注意事项

  • setex(set with expire)键秒值
127.0.0.1:6379> setex mess01 10 hello,you
OK
127.0.0.1:6379> get mess01
"hello,you"
127.0.0.1:6379> get mess01
"hello,you"
127.0.0.1:6379> get mess01
"hello,you"
127.0.0.1:6379> get mess01
"hello,you"
127.0.0.1:6379> get mess01
(nil)  //mess01有效期就10秒,10秒后就销毁
127.0.0.1:6379>
  • mset[同时设置一个或多个key-value对]

​ MSET key vlaue [key value …]

​ 同时设置一个或多个key-value对

​ 如果某个给定key值已经存在,那么MSET会用新值覆盖原来的旧值

127.0.0.1:6379> mset worker01 tom worker02 scott
OK
127.0.0.1:6379> get worker01
"tom"
127.0.0.1:6379> get worker02
"scott"
127.0.0.1:6379> mget worker01 worker02
1) "tom"
2) "scott"
3)Hash

(哈希,类似于golang里的Map)-介绍

Redis hash是一个键值对象集合。var user1 map[string]string

Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象

举例。存放一个User信息

user1 name  张三 age 10
说明
key : user1
name 张三 和 age 30 就是两对 field-value

实操:演示添加user的信息案例(name age job)

127.0.0.1:6379> hset user1 name "smith"
(integer) 1
127.0.0.1:6379> hset user1 age 30
(integer) 1
127.0.0.1:6379> hset user1 job "golang coder"
(integer) 1
127.0.0.1:6379> hget user1 name
"smith"
127.0.0.1:6379> hget user1 age
"30"
127.0.0.1:6379> hget user1 job
"golang coder"
127.0.0.1:6379>

Hash使用细节和注意事项

在给user设置name和age时,前面我们是一步一步设置,使用hmset和hmget可以一次性来设置多个field的值和返回多个field的值

127.0.0.1:6379> hmset user2 name jerry age 110 job "java coder"
OK
127.0.0.1:6379> hmget user2 name age job
1) "jerry"
2) "110"
3) "java coder"
127.0.0.1:6379>

hlen统计一个hash有几个元素

127.0.0.1:6379> hlen user2
(integer) 3
127.0.0.1:6379>

hexists key field

查看哈希表key中,给定域field是否存在

127.0.0.1:6379> hexists user2 name
(integer) 1
127.0.0.1:6379>
4)List

-1.(列表)-介绍

列表是简单的字符串列表,按照插入顺序排序,你可以添加一个元素到列表头部(左边)或者尾部(右边)

List的本质是一个链表,List的元素的有序的,元素的值可以重复

举例,存放多个地址信息

city 北京 天津 上海
说明
北京 天津 上海 就是三个元素
127.0.0.1:6379> lpush city beijing shanghai tianjing
(integer) 3
127.0.0.1:6379> lrange city 0 -1(0表示开头 -1表示尾部)
1) "tianjing"
2) "shanghai"
3) "beijing"
127.0.0.1:6379>

-2.关于list的基本命令介绍

lpush:从左边插入数据

rpush:从右边插入数据

lrange: 用法 lrange key start stop :返回列表key中指定区间内的元素,区间以偏移量start和stop指定,下标(index)参数start和stop都是以0为底,也就是说,以0表示列表的第一个元素,以1表示列表的第二个元素,以此类推。你也可以使用函数负数下标,以-1表示列表的最后一个元素,-2表示列表的倒数第二个元素,以此类推

lpop :从我们列表的左边弹出一个数据

rpop :从我们列表的右边弹出一个数据

del : 删掉这个列表

实战演示

127.0.0.1:6379> lpush herolist aa bb cc
(integer) 3
127.0.0.1:6379> lrange herolist 0 -1
1) "cc"
2) "bb"
3) "aa"
127.0.0.1:6379> rpush herolist dd eee
(integer) 5
127.0.0.1:6379> lrange herolist 0 -1
1) "cc"
2) "bb"
3) "aa"
4) "dd"
5) "eee"
127.0.0.1:6379> lpop herolist
"cc"
127.0.0.1:6379> lrange herolist 0 -1
1) "bb"
2) "aa"
3) "dd"
4) "eee"
127.0.0.1:6379> rpop herolist
"eee"
127.0.0.1:6379> lrange herolist 0 -1
1) "bb"
2) "aa"
3) "dd"
127.0.0.1:6379> del herolist
(integer) 1
127.0.0.1:6379> lrange herolist 0 -1
(empty list or set)
127.0.0.1:6379> 

-3.List-使用细节和注意事项

(1)index,按照索引下标获得元素(从左到右,编号从0开始)

(2)LLEN key ,返回列表key的长度,如果key不存在,则key被解释为一个空列表,返回0

(3)List的其他说明

  • List数据,可以从左或者右,插入添加
  • 如果值全移除,对应的键也就消失了
5)Set

(集合)-介绍

Redis的Set是string类型的无序集合。

底层是HashTble数据结构,Set也是存放很多字符串元素,字符串元素是无序的,而且元素的值不能重复

举例,存放多个邮件列表信息

email sggg@sohu.com tom@sohu.com
说明
key :email
sggg@sohu.com tom@sohu.com 这两个就是元素

关于set的基本命令

sadd :添加元素

smembers :取出所有值

sismember :判断是否存在该成员

srem :删除指定值

127.0.0.1:6379> sadd emails tom@sohu.com jack@qq.com
(integer) 2
127.0.0.1:6379> smembers emails
1) "tom@sohu.com"
2) "jack@qq.com"
127.0.0.1:6379> sadd emails kk@yy.com uu@qq.com
(integer) 2
127.0.0.1:6379> smembers emails
1) "uu@qq.com"
2) "tom@sohu.com"
3) "jack@qq.com"
4) "kk@yy.com"
127.0.0.1:6379> sadd emails jack@qq.com
(integer) 0  //0表示添加失败,因为set的元素是不可以重复的
127.0.0.1:6379> sismember emails tom@sohu.com
(integer) 1 //查看set里面是否含有tom@souhu.com这个元素 1代表存在 0代表不存在
127.0.0.1:6379> sismember emails tom~@sohu.com
(integer) 0
127.0.0.1:6379> srem emails tom@sohu.com
(integer) 1 //演示删除元素
127.0.0.1:6379> smembers emails
1) "kk@yy.com"
2) "uu@qq.com"
3) "jack@qq.com"
127.0.0.1:6379>

二、go操作redis

1、安装第三方开源的redis库

1)使用第三方开源的redis库:github.com/garyburd/redigo/redis

2)在使用redis前,先安装第三方Redis库,在GOPATH路径下执行安装指令:

D:\myfile\go\project>go get github.com/garyburd/redigo/redis

3)安装之后,可以看到如下包

在这里插入图片描述

特别说明:在安装Redis 库之前,确保已经安装并配置了git,因为是从github上下载安装库的,需要使用到git

2、使用go语言开始进行操作

Set/Get接口

1)操作string

说明:通过golang添加和获取key-value【比如name-tom~】

package main
import ("fmt""github.com/garyburd/redigo/redis"
)func main() {//通过go向redis写入数据和读取数据//1.连接到redisconn,err := redis.Dial("tcp","127.0.0.1:6379")if err != nil {fmt.Println("redis.Dial err=",err)return}defer conn.Close() //关闭//2.通过go向redis写入数据string [key-val]_, err=conn.Do("Set","name","tomjerry毛毛和老鼠")if err != nil {fmt.Println("set err=",err)return}//3.通过go向redis读入数据string [key-val]r, err :=redis.String(conn.Do("Get","name"))if err != nil {fmt.Println("Get err=",err)return}//返回的r是interfacce{}//因为name对应的值是字符串,因此我们需要转换[在一开始就用redis提供的方法进行转换]//nameString := r.(string) errofmt.Println("操作成功!",r) //操作成功! tomjerry毛毛和老鼠
}
2)操作hash

说明:通过Golang对redis操作Hash数据类型

package main
import ("fmt""github.com/garyburd/redigo/redis"
)
func main() {//通过go向redis写入数据和读取数据//1.连接到redisconn,err := redis.Dial("tcp","127.0.0.1:6379")if err != nil {fmt.Println("redis.Dial err=",err)return}defer conn.Close() //关闭//2.通过go向redis写入数据string [key-val]//写入名字_, err=conn.Do("HSet","user01","name","john")if err != nil {fmt.Println("hset err=",err)return}//写入age_, err=conn.Do("HSet","user01","age",10)if err != nil {fmt.Println("hset err=",err)return}//3.通过go向redis读入数据string [key-val]r1, err :=redis.String(conn.Do("HGet","user01","name"))if err != nil {fmt.Println("hGet err=",err)return}r2, err :=redis.Int(conn.Do("HGet","user01","age"))if err != nil {fmt.Println("hGet err=",err)return}fmt.Printf("操作成功! r1=%v,r2=%v\n",r1,r2) //操作成功! r1=john,r2=10
}
3)批量操作Set/Get数据

说明:通过Golang对Redis操作,一次操作可以Set/Get多个key-val数

package main
import ("fmt""github.com/garyburd/redigo/redis"
)
func main() {//通过go向redis写入数据和读取数据//1.连接到redisconn,err := redis.Dial("tcp","127.0.0.1:6379")if err != nil {fmt.Println("redis.Dial err=",err)return}defer conn.Close() //关闭//2.通过go向redis写入数据string [key-val]//写入名字和年龄_, err=conn.Do("HMSet","user02","name","tom","age",19)if err != nil {fmt.Println("HMSet err=",err)return}//3.通过go向redis读入数据string [key-val]r, err :=redis.Strings(conn.Do("HMGet","user02","name","age"))if err != nil {fmt.Println("hGet err=",err)return}// fmt.Printf("r=%v\n",r) //r=[tom 19]for i,v := range r {fmt.Printf("r[%d]=%v\n",i,v)}}
4)给数据设置有效时间

说明:通过golang对redis操作,给key-value设置有效时间

core code

//给name数据设置有效时间10s
_,err =c.Do("expire","name",10)

5)操作List

说明:通过golang对redis操作list数据类型

corecode

_,err=c.Do("lpush","herolist","no1.宋江",30,"no2.吴用",28)
5)课堂练习

在这里插入图片描述

package main
import ("fmt""github.com/garyburd/redigo/redis"
)func main() {var names stringvar ages intvar skills string//1.连接到redisconn,err := redis.Dial("tcp","127.0.0.1:6379")if err != nil {fmt.Println("redis.Dial err=",err)return}defer conn.Close() //关闭fmt.Println("请输入names: ")fmt.Scan(&names)fmt.Println("请输入ages: ")fmt.Scan(&ages)fmt.Println("请输入skills: ")fmt.Scan(&skills)//go操作redis进行写的操作_, err=conn.Do("HMSet","monster","name",names,"age",ages,"skill",skills)if err != nil {fmt.Println("HMSet err=",err)return}//go操作redis进行读的操作r, err :=redis.Strings(conn.Do("HMGet","monster","name","age","skill"))if err != nil {fmt.Println("HMGet err=",err)return}for i,v := range r{fmt.Printf("r[%d]=%v\n",i,v)}fmt.Println("操作完成")}
6)Redis连接池

说明:通过Golang对redis的操作,还可以通过redis连接池,流程如下

-1.事先初始化一定数量的连接,放入到连接池

-2.当go需要操作redis时,直接从redis连接池取出连接即可

-3.这样可以节省临时获取redis连接的时间,从而提高效率

core code

var pool *redis.Pool
pool = &redis.Pool{MaxIdle:8MaxActive:0IdleTimeout:100Dial:func()(redis.Conn,error){return redis.Dial("tcp","localhost:6379")},
}
c :=pool.Get()

-4.示意图

在这里插入图片描述

package main
import ("fmt""github.com/garyburd/redigo/redis"
)
//定义一个全局的pool
var pool *redis.Pool//当启动程序时就初始化连接池
func init() {pool = &redis.Pool{MaxIdle:8, //最大空闲连接数MaxActive:0,//表示和数据库的最大连接数,0表示没有限制IdleTimeout:100,//最大空闲时间Dial:func()(redis.Conn,error){//初始化连接的代码。连接哪个ipreturn redis.Dial("tcp","localhost:6379")},}
}
func main() {//先从pool池取出一个连接conn := pool.Get()defer conn.Close()_, err :=conn.Do("Set","name","汤姆猫~~")if err != nil {fmt.Println("conn.Do err=",err)return}//取出r,err :=redis.String(conn.Do("Get","name"))if err != nil {fmt.Println("conn.Do err=",err)return}fmt.Println("r=",r)}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/226832.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java导出word使用模版与自定义联合出击解决复杂表格!

1. 看一下需要导出什么样子的表格 如图所示,这里的所有数据行都是动态的,需要根据查询出来的数据循环展示。 如果只是这样的话,使用freemarker应该都可以搞定,但是他一列中内容相同的单元格,需要合并。 这对于表格样式…

conda命令克隆(复制)环境

前情介绍 最近有个需求是:根据已有的环境生成一个新的环境,也就是所需的新环境有大多数包和已有的环境都是相同的,需要改的只是部分,所以呢,克隆一个就再适合不过了! 所需命令 conda create -n B --clone…

java设计模式-工厂方法模式

1.工厂方法(FactoryMethod)模式的定义 定义一个创建产品对象的工厂接口,将产品对象的实际创建工作推迟到具体子工厂类当中。这满足创建型模式中所要求的“创建与使用相分离”的特点。 2.工厂方法模式的主要优缺点 优点: 用户只需要知道具体工厂的名称…

HPM6750系列--第九篇 GPIO详解(基本操作)

一、目的 在之前的博文中我们主要介绍了不同系统不同开发编译调试环境的配置和操作(命令行方式、Visual Studio Code、Segger Embedded Studio for RISC-V),以帮助大家准备好学习环境为目的,但是未涉及到芯片本身以及外设的讲解。…

【linux】图形界面Debian的root用户登陆

图形界面Debian默认不允许以root用户登录。这是出于安全考虑,以防止用户使用root权限执行可能损害系统的操作。 如果需要使用root用户,可以通过以下步骤进行登录: 打开终端,使用su命令切换到root用户。修改/etc/gdm3/daemon.con…

大型网站架构演进过程

架构演进 大型网站的技术挑战主要来自于庞大的用户,高并发的访问和海量的数据,任何简单的业务一旦需要处理数以P计的数据和面对数以亿计的用户,问题就会变得很棘手。大型网站架构主要就是解决这类问题。 架构选型是根据当前业务需要来的&…

时序预测 | Python实现XGBoost电力需求预测

时序预测 | Python实现XGBoost电力需求预测 目录 时序预测 | Python实现XGBoost电力需求预测预测效果基本描述程序设计参考资料预测效果 基本描述 该数据集因其每小时的用电量数据以及 TSO 对消耗和定价的相应预测而值得注意,从而可以将预期预测与当前最先进的行业预测进行比较…

JS中的String常用的实例方法

splice():分隔符 把字符串以分隔符的形式拆分为数组 const str pink,red;const arr str.split(,);console.log(arr);//Array[0,"pink";1:"red"]const str1 2022-4-8;const arr1 str1.split(-);console.log(arr1);//Array[0,"2022";1:"…

Vue3快速上手笔记

Vue3快速上手 1.Vue3简介 2020年9月18日,Vue.js发布3.0版本,代号:One Piece(海贼王)耗时2年多、2600次提交、30个RFC、600次PR、99位贡献者github上的tags地址:https://github.com/vuejs/vue-next/release…

实操Nginx(七层代理)+Tomcat多实例部署,实现负载均衡和动静分离

目录 Tomcat多实例部署(192.168.17.27) 1.安装jdk,设置jdk的环境变量 2.安装tomcat在一台已经部署了tomcat的机器上复制tomcat的配置文件取名tomcat1 ​编辑 编辑配置文件更改端口号,将端口号改为8081 启动 tomcat&#xff…

SpringBoot之响应的详细解析

2. 响应 前面我们学习过HTTL协议的交互方式:请求响应模式(有请求就有响应) 那么Controller程序呢,除了接收请求外,还可以进行响应。 2.1 ResponseBody 在我们前面所编写的controller方法中,都已经设置了…

Linux面试题精选:提升你的面试准备

大家有关于JavaScript知识点不知道可以去 🎉博客主页:阿猫的故乡 🎉系列专栏:JavaScript专题栏 🎉ajax专栏:ajax知识点 🎉欢迎关注:👍点赞🙌收藏✍️留言 学习…

CD8+T细胞通过NKG2D-NKG2DL轴维持对MHC-I阴性肿瘤细胞的杀伤

今天给同学们分享一篇实验文章“CD8 T cells maintain killing of MHC-I-negative tumor cells through the NKG2D-NKG2DL axis”,这篇文章发表在Nat Cancer期刊上,影响因子为22.7。 结果解读: MHC-I阴性肿瘤的免疫疗法需要CD8 T细胞 作者先…

下午好~ 我的论文【yolo1~4】(第二期)

写在前面:本来是一期的,我看了太多内容了,于是分成三期发吧 TAT (捂脸) 文章目录 YOLO系列v1v2v3v4 YOLO系列 v1 You Only Look Once: Unified, Real-Time Object Detection 2015 ieee computer society 12.3 CCF-C…

高云GW1NSR-4C开发板M3核串口通信

1.PLLVR频率计算 高云的M3核要用到PLLVR核,其输出频率FCLKIN*(FBDIV_SEL1)/(IDIV_SEL1),但同时要满足FCLKIN*(FBDIV_SEL1)*ODIV_SEL)/(IDIV_SEL1)的值在600MHz和1200MHz之间。例如官方示例,其输入频率FCLKIN50MHz,要输出80MHz&am…

appium2.0.1安装完整教程+uiautomator2安装教程

第一步:根据官网命令安装appium(Install Appium - Appium Documentation) 注意npm前提是设置淘宝镜像: npm config set registry https://registry.npmmirror.com/ 会魔法的除外。。。 npm i --locationglobal appium或者 npm…

oracle DG 三种应用机制

首先理解不管是哪种机制,oracle都不是从主库直接传归档文件到备库,而是通过网络将主库的redo数据传输到备库: 1、普通DG是主库发生日志切换,备库把接收到的redo数据在备库通过归档进程生成为归档文件进行应用 2、ADG则是备库把接收…

Java技术栈 —— 微服务框架Spring Cloud —— Ruoyi-Cloud 学习(二)

RuoYi项目开发过程 一、登录功能(鉴权模块)1.1 后端部分1.1.1 什么是JWT?1.1.2 什么是Base64?为什么需要它?1.1.3 SpringBoot注解解析1.1.4 依赖注入和控制反转1.1.5 什么是Restful?1.1.6 Log4j 2、Logpack、SLF4j日志框架1.1.7 如何将项目打包成指定bytecode字节…

基于springboot的教学在线作业管理系统(源码+调试)

项目描述 临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。你想解决的问题,今天给大家介绍…