Redis的具体使用-Redis学习笔记二

1. key的操作

redis里边,除了\n空格 不能作为名字的组成内容外,其他内容都可以作为key的名字部分。名字长度不做要求。

 

不同redis数据库切换:

用select  ,默认是操作数据库0,默认共有16个数据库,所以数据库Index是从0到15

操作例子

 

[root@fengniu020 ~]# cd /usr/local/
[root@fengniu020 local]# cd redis/
[root@fengniu020 redis]# l
-bash: l: command not found
[root@fengniu020 redis]# ls
dump.rdb  redis-cli  redis.conf  redis-server
[root@fengniu020 redis]# ./redis-cli 
redis 127.0.0.1:6379> key *
(error) ERR unknown command 'key'
redis 127.0.0.1:6379> keys *
1) "name"
2) "addr"
3) "age"
redis 127.0.0.1:6379> del addr
(integer) 1
redis 127.0.0.1:6379> keys *
1) "name"
2) "age"
redis 127.0.0.1:6379> type age
string
redis 127.0.0.1:6379> set fuck 123
OK
redis 127.0.0.1:6379> keys *
1) "name"
2) "fuck"
3) "age"
redis 127.0.0.1:6379> type fuck
string
redis 127.0.0.1:6379> keys *e
1) "name"
2) "age"
redis 127.0.0.1:6379> rename fuck fuckyou
OK
redis 127.0.0.1:6379> get fuckyou
"123"
redis 127.0.0.1:6379> dbsize
(integer) 3
redis 127.0.0.1:6379> expire age 10
(integer) 1
redis 127.0.0.1:6379> ttl age
(integer) 0
redis 127.0.0.1:6379> keys *
1) "name"
2) "fuckyou"
redis 127.0.0.1:6379> set age 12
OK
redis 127.0.0.1:6379> expire age 20
(integer) 1
redis 127.0.0.1:6379> ttl age
(integer) 17
redis 127.0.0.1:6379> keys *
1) "name"
2) "age"
3) "fuckyou"
redis 127.0.0.1:6379> ttl age
(integer) 8
redis 127.0.0.1:6379> select 1
OK
redis 127.0.0.1:6379[1]> select 0
OK
redis 127.0.0.1:6379> move fuckyou 1
(integer) 1
redis 127.0.0.1:6379> select 1
OK
redis 127.0.0.1:6379[1]> keys *
1) "fuckyou"
redis 127.0.0.1:6379[1]> flushdb
OK
redis 127.0.0.1:6379[1]> keys *
(empty list or set)
redis 127.0.0.1:6379[1]> flushall
OK
redis 127.0.0.1:6379[1]> select 0
OK
redis 127.0.0.1:6379> keys *
(empty list or set)
redis 127.0.0.1:6379> 

 

 

 

2. String类型操作

 

string是redis最基本的类型

redis的string可以包含任何数据。包括jpg图片或者序列化的对象。

单个value值最大上限是1G字节。 

如果只用string类型,redis就可以被看作加上持久化特性的memcache

 

incr:  increament  增长

      该指令可以对key进行累加1操作,默认是累加1操作,类似i++操作

      该指令可以针对 新key已有key 进行操作

新key:创建该key并累加1,其值为1

已有key:key的信息值类型要求必须为整型的

decr  的操作模式与incr一致,不过是减1操作

substr: 对内容进行截取,包括startend标记位置内容

操作示例

 

redis 127.0.0.1:6379> keys *
(empty list or set)
redis 127.0.0.1:6379> set age 18
OK
redis 127.0.0.1:6379> set name lily
OK
redis 127.0.0.1:6379> set addr guangzhou
OK
redis 127.0.0.1:6379> keys *
1) "name"
2) "addr"
3) "age"
redis 127.0.0.1:6379> mset tel 10086 wife lucy
OK
redis 127.0.0.1:6379> keys *
1) "addr"
2) "age"
3) "name"
4) "wife"
5) "tel"
redis 127.0.0.1:6379> mget wife tel name
1) "lucy"
2) "10086"
3) "lily"
redis 127.0.0.1:6379> incr tel
(integer) 10087
redis 127.0.0.1:6379> incr lily
(integer) 1
redis 127.0.0.1:6379> get name
"lily"
redis 127.0.0.1:6379> get age
"18"
redis 127.0.0.1:6379> incr age
(integer) 19
redis 127.0.0.1:6379> decr age
(integer) 18
redis 127.0.0.1:6379> incrby age 2
(integer) 20
redis 127.0.0.1:6379> decrby age 2
(integer) 18
redis 127.0.0.1:6379> append name andlucy
(integer) 11
redis 127.0.0.1:6379> get name
"lilyandlucy"
redis 127.0.0.1:6379> substr name 7 10
"lucy"
redis 127.0.0.1:6379> 

 

 

 

redis 127.0.0.1:6379> get lala
"lala"
redis 127.0.0.1:6379> setnx lala 'lala_new'
(integer) 0
redis 127.0.0.1:6379> get lala
"lala"
redis 127.0.0.1:6379> setex haircolor 10 red
OK
redis 127.0.0.1:6379> get haircolor
"red"
redis 127.0.0.1:6379> get haircolor
(nil)
redis 127.0.0.1:6379> set email liuzp@163.com
OK
redis 127.0.0.1:6379> get email
"liuzp@163.com"
redis 127.0.0.1:6379> setrange email 7 gmail.com
(integer) 16
redis 127.0.0.1:6379> get email
"liuzp@1gmail.com"
redis 127.0.0.1:6379> setrange email 6 gmail.com
(integer) 16
redis 127.0.0.1:6379> get email
"liuzp@gmail.comm"
redis 127.0.0.1:6379> 

 

 

 

3. 数据类型List链表

 

list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。

这使得list既可以用作栈,也可以用作队列。

上进上出 :

上进下出 队列

 

 

 

该list链表类型应用场合:

获得最新的10个登录用户信息: select * from user order by logintime desc limit 10;

以上sql语句可以实现用户需求,但是数据多的时候,全部数据都要受到影响,对数据库的负载比较高。必要情况还需要给关键字段(id或logintime)设置索引索引也比较耗费系统资源

如果通过list链表实现以上功能,可以在list链表中保留最新的10个数据,每进来一个新数据就删除一个旧数据。每次就可以从链表中直接获得需要的数据。极大节省各方面资源消耗

 

 

 

通过list链表保存登录系统的最新5个用户信息:

jim   xiaoli  jack   xiaoming   linken   mary  tom

 

设置一个list链表key  newlogin,内部有5个元素:

redis 127.0.0.1:6379> lpush newlogin tom
(integer) 1
redis 127.0.0.1:6379> lpush newlogin mary
(integer) 2
redis 127.0.0.1:6379> lpush newlogin linken
(integer) 3
redis 127.0.0.1:6379> lpush newlogin xiaoming
(integer) 4
redis 127.0.0.1:6379> lpush newlogin jack
(integer) 5

 

该链表每增加一个新元素,就删除一个旧元素:

 

redis 127.0.0.1:6379> lpush newlogin xiaoli
(integer) 6
redis 127.0.0.1:6379> rpop newlogin
"tom"

 

通过范围查找链表内部的全部元素信息:

 

redis 127.0.0.1:6379> lrange newlogin 0 5
1) "xiaoli"
2) "jack"
3) "xiaoming"
4) "linken"
5) "mary"
redis 127.0.0.1:6379> lrange newlogin 0 100
1) "xiaoli"
2) "jack"
3) "xiaoming"
4) "linken"
5) "mary"

 

4. set集合类型

 

redis的set是string类型的无序集合。

set元素最大可以包含(2的32次方-1)个元素。

关于set集合类型除了基本的添加删除操作,其他有用的操作还包含集合的取并集(union),交集(intersection),差集(difference)。通过这些操作可以很容易的实现sns中的好友推荐功能

 

注意:每个集合中的各个元素不能重复

 

 

 

该类型应用场合:qq好友推荐

 

tom朋友圈(与某某是好友):mary  jack  xiaoming  wang5  wang6

linken朋友圈(与某某是好友):yuehan  daxiong  luce  wang5  wang6

 

创建tomSet的set集合类型数据,内部有5个元素:

redis 127.0.0.1:6379> keys *
(empty list or set)
redis 127.0.0.1:6379> sadd tomSet mary
(integer) 1
redis 127.0.0.1:6379> sadd tomSet jack
(integer) 1
redis 127.0.0.1:6379> sadd tomSet xiaoming
(integer) 1
redis 127.0.0.1:6379> sadd tomSet wang5
(integer) 1
redis 127.0.0.1:6379> sadd tomSet wang6
(integer) 1
redis 127.0.0.1:6379> keys *
1) "tomSet"

 

再创建一个linkenSet的set集合key:

 

 

redis 127.0.0.1:6379> keys *
1) "tomSet"
redis 127.0.0.1:6379> sadd linkenSet yuehan
(integer) 1
redis 127.0.0.1:6379> sadd linkenSet daxiong
(integer) 1
redis 127.0.0.1:6379> sadd linkenSet lucy
(integer) 1
redis 127.0.0.1:6379> sadd linkenSet wang5
(integer) 1
redis 127.0.0.1:6379> sadd linkenSet wang6
(integer) 1
redis 127.0.0.1:6379> keys *
1) "tomSet"
2) "linkenSet"

 

两个集合取交集并集

 

redis 127.0.0.1:6379> keys *
1) "tomSet"
2) "linkenSet"
redis 127.0.0.1:6379> sinter tomSet linkenSet
1) "wang5"
2) "wang6"
redis 127.0.0.1:6379> sunion tomSet linkenSet
1) "xiaoming"
2) "mary"
3) "wang5"
4) "lucy"
5) "wang6"
6) "daxiong"
7) "yuehan"
8) "jack"

两个集合互取差集

 

redis 127.0.0.1:6379> sdiff tomSet linkenSet
1) "xiaoming"
2) "mary"
3) "jack"
redis 127.0.0.1:6379> sdiff linkenSet tomSet
1) "lucy"
2) "yuehan"
3) "daxiong"

 

 

 

 

 

 

 

5. Sort Set排序集合类型

 

和set一样sorted set也是string类型元素的集合,

不同的是每个元素都会关联一个

通过权值可以有序的获取集合中的元素

 

该Sort set类型适合场合:

获得热门帖子(回复量)信息:select * from message order by backnum desc limit 5;

(以上需求可以通过简单sql语句实现,但是sql语句比较耗费mysql数据库资源)

 

案例:利用sort set实现获取最热门的5帖子信息

(以回复量决定是否为热门帖子)

 

排序集合中的每个元素都是的组合

(之前的set集合类型每个元素就只是一个 )

 

我们做一个sort set排序集合,里边只保留5个元素信息,该5个元素是回复量最高的贴,

每个帖子被回复的时候,都有机会进入该集合里边,但是只有回复量最高的前5个帖子会存在于在集合,回复量低的就被删除。

关于重复元素:

set类型:没有

list链表类型:

Sort set类型:没有

zremrangebyrank 删除按权值从小到大排序后,给定范围的元素,先删除小的

创建一个sort set 排序集合hotmessage的key,内部有5个元素:

redis 127.0.0.1:6379> zadd hotmessage 102 11
(integer) 1
redis 127.0.0.1:6379> zadd hotmessage 141 12
(integer) 1
redis 127.0.0.1:6379> zadd hotmessage 159 13
(integer) 1
redis 127.0.0.1:6379> zadd hotmessage 72 14
(integer) 1
redis 127.0.0.1:6379> zadd hotmessage 203 15
(integer) 1
redis 127.0.0.1:6379> keys *
1) "tomSet"
2) "linkenSet"
3) "hotmessage"

 

按照权值由高到低的顺序获得具体元素值的信息:

 

redis 127.0.0.1:6379> zrevrange hotmessage 0 100
1) "15"
2) "13"
3) "12"
4) "11"
5) "14"
redis 127.0.0.1:6379> zadd hotmessage 189 16
(integer) 1
redis 127.0.0.1:6379> zrevrange hotmessage 0 100
1) "15"
2) "16"
3) "13"
4) "12"
5) "11"
6) "14"

 

增加一个新元素,就删除一个旧元素(回复量最低的)

 

redis 127.0.0.1:6379> zremrangebyrank hotmessage 0 0
(integer) 1
redis 127.0.0.1:6379> zrevrange hotmessage 0 100
1) "15"
2) "16"
3) "13"
4) "12"
5) "11"

 

排序集合其他操作

 

redis 127.0.0.1:6379> zrank hotmessage 15
(integer) 4
redis 127.0.0.1:6379> zrank hotmessage 11
(integer) 0
redis 127.0.0.1:6379> zrank hotmessage 12
(integer) 1
redis 127.0.0.1:6379> zrevrank hotmessage 11
(integer) 4
redis 127.0.0.1:6379> zcard hotmessage
(integer) 5
redis 127.0.0.1:6379> zscore 11
(error) ERR wrong number of arguments for 'zscore' command
redis 127.0.0.1:6379> zscore hotmessage 11
"102"
redis 127.0.0.1:6379> zrem 11
(error) ERR wrong number of arguments for 'zrem' command
redis 127.0.0.1:6379> zrem hotmessage 11
(integer) 1
redis 127.0.0.1:6379> zrevrange hotmessage 0 1000
1) "15"
2) "16"
3) "13"
4) "12"
redis 127.0.0.1:6379> zincrby hotmessage 200 12
"341"
redis 127.0.0.1:6379> zrevrange hotmessage 0 100
1) "12"
2) "15"
3) "16"
4) "13"
redis 127.0.0.1:6379> 

 


 

 

 

 

 

 

6. Hash类型

 

 

 

hash类型操作示例:

 

redis 127.0.0.1:6379> hmset goods goods_id 9 goods_name iphone6 goods_weight 120 goods_price 4
OK
redis 127.0.0.1:6379> hkeys goods
1) "goods_id"
2) "goods_name"
3) "goods_weight"
4) "goods_price"
5) "goods_number"
redis 127.0.0.1:6379> hvals goods
1) "9"
2) "iphone6"
3) "120"
4) "4500"
5) "4"
redis 127.0.0.1:6379> hset lucy age 10
(integer) 1
redis 127.0.0.1:6379> keys *
1) "lucy"
2) "goods"
redis 127.0.0.1:6379> hset lucy name lucy
(integer) 1
redis 127.0.0.1:6379> hset lucy addr beijing
(integer) 1
redis 127.0.0.1:6379> hget lucy
(error) ERR wrong number of arguments for 'hget' command
redis 127.0.0.1:6379> hget lucy name
"lucy"
redis 127.0.0.1:6379> hmget name age addr
1) (nil)
2) (nil)
redis 127.0.0.1:6379> hmget lucy  name age addr
1) "lucy"
2) "10"
3) "beijing"
redis 127.0.0.1:6379> hincrby lucy age 10
(integer) 20
redis 127.0.0.1:6379> hexists lucy age
(integer) 1
redis 127.0.0.1:6379> hexists lucy age0
(integer) 0
redis 127.0.0.1:6379> hdel lucy age
(integer) 1
redis 127.0.0.1:6379> hexists lucy age
(integer) 0
redis 127.0.0.1:6379> hlen lucy
(integer) 2
redis 127.0.0.1:6379> hkeys lucy
1) "name"
2) "addr"
redis 127.0.0.1:6379> hvals lucy
1) "lucy"
2) "beijing"
redis 127.0.0.1:6379> hgetall goods
 1) "goods_id"
 2) "9"
 3) "goods_name"
 4) "iphone6"
 5) "goods_weight"
 6) "120"
 7) "goods_price"
 8) "4500"
 9) "goods_number"
10) "4"
redis 127.0.0.1:6379> 

 

 

参考学习网站:  Redis 命令参考

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
尚硅谷是一个教育机构,他们提供了一份关于Redis学习笔记。根据提供的引用内容,我们可以了解到他们提到了一些关于Redis配置和使用的内容。 首先,在引用中提到了通过执行命令"vi /redis-6.2.6/redis.conf"来编辑Redis配置文件。这个命令可以让你进入只读模式来查询"daemonize"配置项的位置。 在引用中提到了Redis会根据键值计算出应该送往的插槽,并且如果不是该客户端对应服务器的插槽,Redis会报错并告知应该前往的Redis实例的地址和端口。 在引用中提到了通过修改Redis的配置文件来指定Redis的日志文件位置。可以使用命令"sudo vim /etc/redis.conf"来编辑Redis的配置文件,并且在文件中指定日志文件的位置。 通过这些引用内容,我们可以得出结论,尚硅谷的Redis学习笔记涵盖了关于Redis的配置和使用的内容,并提供了一些相关的命令和操作示例。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Redis学习笔记--尚硅谷](https://blog.csdn.net/HHCS231/article/details/123637379)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Redis学习笔记——尚硅谷](https://blog.csdn.net/qq_48092631/article/details/129662119)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值