Redis基础知识

一、什么是Redis

Redis是现在最受欢迎的NoSQL数据库之一,是一款内存高速缓存数据库。Redis全称为:Remote Dictionary Server (远程字典服务),Redis是一个使用ANSI C编写的开源、包含多种数据结构、支持网络、基于内存、可选持久性的键值对存储数据库,其具备如下特性:

  • 基于内存运行,性能高效
  • 支持分布式,理论上可以无限扩展
  • key-value存储系统
  • 开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API

相比于其他数据库类型,Redis具备的特点是:

  • C/S通讯模型
  • 单进程单线程模型
  • 丰富的数据类型
  • 操作具有原子性
  • 持久化
  • 高并发读写
  • 支持lua脚本

二、为什么使用Redis

  1. 简单稳定
  • Redis使用单线程模型
  • Redis源码较少
  • Redis依赖操作系统库少
  1. 运行速度快
  • 基于内存运行
  • C语言实现
  • Redis命令是单线程执行的,避免了多线程频繁切换性能的问题(官方给的结果是读写性能达到每秒10万次以上,具体取决于机器的性能)
  1. 具有丰富的功能
  • 提供了常用的String、List、Set、Hash、Zset 5种数据类型外,还提供了Stream、Geospatial、HyperLogLog、BitBitmap等数据类型
  • 提供了键过期的功能,可以用来实现缓存
  • 提供了发布和订阅功能,可以用作消息系统
  • 提供简单的事务功能,在一定程度上能保证事务
  • 支持Lua脚本扩展能力,可以结合Lua脚本实现新的命令
  • 提供了管道能力,能将多条命令一次性传到Redis执行,减少网络开销
  1. 具备高可扩展、高性能和高可用特性
  • 提供了RDB和AOF两种持久化方式,将内存数据保存在硬盘中,即使发生断电或服务器故障,也能保证数据安全
  • Redis 2.8 版本提供了Redis Sentinel实现了高可用,保证了Redis节点的故障发现和故障自动转移;3.0版本提供了Redis Cluster,提高了读写和容量的扩展性
  • 几乎所有主流编程语言都支持Redis

三、Redis的应用场景

​ 众多语言都支持Redis,因为Redis交换数据快,在服务器中常用来存储一些需要频繁调取的数据,节省内存开销,也极大的提升了速度。

​ 将一些热点数据存储到Redis中,要用的时候,直接从内存取,极大的提高了速度和节约了服务器的开销。

​ 1、缓存

​ 2、会话缓存

​ 3、消息队列

​ 4、活动排行榜或计数

​ 5、发布/订阅消息

​ 6、商品列表,评论列表

​ 7、分布式锁

​ 8、热点数据

​ 9、其他

四、Redis的部署和配置

前提:

由于 redis 是用 C 语言开发,安装之前必先确认是否安装 gcc 环境(gcc -v),

如果没有安装,执行命令 yum install -y gcc 进行安装

1、下载并解压安装包
wget http://download.redis.io/releases/redis-5.0.3.tar.gz
tar -zxvf redis-5.0.3.tar.gz
2、编译
cd redis-5.0.3
make
3、安装并指定安装目录
make install PREFIX=/usr/local/redis
4、启动服务

前台启动:

cd /usr/local/redis/bin/
./redis-server

后台启动:

从 redis 的源码目录中复制 redis.conf 到 redis 的安装目录

cp /usr/local/redis-5.0.3/redis.conf /usr/local/redis/bin/

修改 redis.conf 文件

vi redis.conf

bind 127.0.0.1 # 将这行代码注释,监听所有的ip地址,外网可以访问 
protected-mode no # 把yes改成no,允许外网访问 
daemonize yes # 把no改成yes,后台运行
requirepass 1q2w3e4r # 注释取消掉设置账号密码

修改保存后,启动

./redis-server redis.conf &
5、查看redis状态
ps -ef | grep redis
6、设置开机启动
vi /etc/systemd/system/redis.service

### 粘贴进去即可
[Unit]
Description=redis-server
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/redis/bin/redis-server /usr/local/redis/bin/redis.conf
PrivateTmp=true

[Install]
WantedBy=multi-user.target

### 执行命令即可
systemctl daemon-reload
systemctl start redis.service
systemctl enable redis.service
7、服务操作命令
systemctl start redis.service  #启动redis服务

systemctl stop redis.service  #停止redis服务

systemctl restart redis.service  #重新启动服务

systemctl status redis.service  #查看服务当前状态

systemctl enable redis.service  #设置开机自启动

systemctl disable redis.service  #停止开机自启动
8、 Redis客户端连接测试
cd /usr/local/redis/bin/
./redis-cli

在这里插入图片描述

五、Redis五大数据类型

1、Redis-Key

# 查看所有的Key
key *  
# set key
set [Key] [Value]
# 获取Key的Value
get [Key]
# 判断Key是否存在
EXISTS [Key]
# 移除Key db代表的是Key在哪个数据库里
move [Key] [db]
# 设置Key的过期时间, 单位是秒
EXPIRE [Key] [seconds]
# 查看Key的过期时间
ttl [Key]
# 查看Key的类型
type [Key]

2、String(字符串)

2.1、set
  • set [key] [value]
  • 设置值
######################################################################################

# 设置值
set [Key] [Value]

# 获取值
get [Key]

# 获取所有Key
key *

# 判断某一个Key是否存在
EXISTS [Key]

# 追加字符串,如果当前的Key不存在, 就相当于SET Key
APPEND [Key] [Value]

######################################################################################

# 自增1
incr [Key]

# 自减1
decr [Key]

# 自增自定义步长
INCRBY [Key] [步长]

# 自减自定义步长
DECRBY [Key] [步长]

######################################################################################

# 字符串的范围 range 
# 截取字符串, START为字符串开始下标, END为字符串的结束下标, -1表示字符串的最大长度
GETRANGE [Key] [START] [END]

# 替换指定位置开始的字符串
SETRANGE [Key] [Offset] [Value]

######################################################################################

# SETEX (set with expire) # 设置过期时间
# SETNX (set if no exist) # 不存在则设置(在分布式锁会常常使用!)

# 设置Key的过期时间
set [Key] [seconds] [Value]

# 如果Key不存在,创建Key, 如果Key存在则创建Key失败
setnx [Key] [Value]

######################################################################################

# 同时设置多个值
mset [Key1] [Value1] [Key2] [Value2] ...

# 同时获取多个值
mget [Key1] [Key2] ...

# msetnx 是一个原子性的操作,要么一起成功,要么一起失败!
msetnx [Key1] [Value1] [Key2] [Value2] ...

######################################################################################
# 实战
######################################################################################

# 对象
set user:1 {name:zhangsan,age:3} # 设置一个User:1 对象值为json字符串来保存一个对象!

# 这里的Key是一个巧妙的设计:user:{id}:{filed}
set user:1 {name:zhangsan, age:3} #设置一个user:1对象值为json字符来保存一个对象!
#这里的key是一个巧妙的设计: user:{id} :{filed} ,如此设计在Redis中是完全OK了!
127.0.0.1:6379> mset user:1:name zhangsan user:1:age 2
о
127.0.0.1:6379> mget user:1:name user:1:age
1) "zhangsan'
2) "2"

######################################################################################

# 先get然后在set, 如果值不存在, 则返回nil;如果存在值,获取原来的值, 并设置新的值
getset [Key] [Value]

######################################################################################

使用场景(字符串或者数字)

  • 计数器
  • 统计多单位的数量
  • 粉丝数

3、List

  • 可以把List玩成栈,队列,阻塞队列!
  • 所有的List的命令都是用l开头的
3.1、Lpush
  • Lpush [List] [Start Index] [End Index]
  • 将一个值或者多个值,插入到列表头部(左)
  ##################################################################################
  # LPUSH [List] [Start Index] [End Index] 将一个值或者多个值,插入到列表头部(左)
  ##################################################################################
  
  127.0.0.1:0>LPUSH list one
  "1"
  127.0.0.1:0>LPUSH list two
  "2"
  127.0.0.1:0>LPUSH list three
  "3"
  127.0.0.1:0>LRANGE list 0 -1
   1)  "three"
   2)  "two"
   3)  "one"
  127.0.0.1:0>LRANGE list 0 1
   1)  "three"
   2)  "two"
  127.0.0.1:0>
  
  ##################################################################################
3.2、Rpush
  • RPUSH [List] [Start Index] [End Index]
  • 将一个值或者多个值,插入到列表尾部(右)
  ####################################################################################
  # RPUSH [List] [Start Index] [End Index] 将一个值或者多个值,插入到列表尾部(右)
  ##################################################################################
  
  127.0.0.1:0>RPUSH list right
  "4"
  127.0.0.1:0>LRANGE list 0 -1
   1)  "three"
   2)  "two"
   3)  "one"
   4)  "right"
  
  ##################################################################################
3.3、Lpop
  • Lpop [List] 与 Rpop [List]
  • 移除左边第一个元素与移除右边第一个元素
  ##################################################################################
  # Lpop [List] 与 Rpop [List] 移除左边第一个元素与移除右边第一个元素
  ##################################################################################
  
  127.0.0.1:6379> LRANGE list 0 -1
  1) "three"
  2) "two"
  3) "one"
  4) "right"
  # 移除左边第一个元素
  127.0.0.1:6379> LPOP list
  "three"
  # 移除右边第一个元素
  127.0.0.1:6379> RPOP list
  "right"
  127.0.0.1:6379> LRANGE list 0 -1
  1) "two"
  2) "one"
  127.0.0.1:6379>
  
  ####################################################################################
3.4、Lindex
  • Lindex [Key]
  • 通过索引获取对应下标的值
  ##################################################################################
  # Lindex [Key] []通过索引获取对应下标的值
  ##################################################################################
  
  127.0.0.1:6379> LRANGE list 0 -1
  1) "two"
  2) "one"
  127.0.0.1:6379> LINDEX list 0
  "two"
  127.0.0.1:6379> LINDEX list 1
  "one"
  
  ##################################################################################
3.5、Llen
  • Llen [Key]
  • 返回列表的长度
  ##################################################################################
  # Llen [Key] 返回列表的长度
  ##################################################################################
  
  127.0.0.1:6379> LPUSH list one
  (integer) 1
  127.0.0.1:6379> LPUSH list two
  (integer) 2
  127.0.0.1:6379> LPUSH list three
  (integer) 3
  127.0.0.1:6379> LLEN list
  (integer) 3
  
  ##################################################################################
3.6、Lrem
  • Lrem(remove) [list] [count] [element]
  • 移除list集合中指定个数的value,精确匹配
  ##################################################################################
  # Lrem [list] [count] [element] 移除list集合中指定个数的value,精确匹配
  ##################################################################################
  
  # 查看list所有的值
  127.0.0.1:6379> LRANGE list 0 -1
  1) "three"
  2) "three"
  3) "two"
  4) "one"
  # 移除list的1个值为one
  127.0.0.1:6379> LREM list 1 one
  (integer) 1
  # 查看list所有的值
  127.0.0.1:6379> LRANGE list 0 -1
  1) "three"
  2) "three"
  3) "two"
  # 移除list的1个值为three
  127.0.0.1:6379> LREM list 1 three
  (integer) 1
  # 查看list所有的值
  127.0.0.1:6379> LRANGE list 0 -1
  1) "three"
  2) "two"
  # 向list的头部添加值为three
  127.0.0.1:6379> LPUSH list three
  (integer) 3
  # 查看list所有的值
  127.0.0.1:6379> LRANGE list 0 -1
  1) "three"
  2) "three"
  3) "two"
  # 移除list的2个值为three
  127.0.0.1:6379> LREM list 2 three
  (integer) 2
  # 查看list所有的值
  127.0.0.1:6379> LRANGE list 0 -1
  1) "two"
  
  ##################################################################################
3.7、Ltrim
  • LTRIM [list] [start] [stop]
  • list 截断
  ##################################################################################
  # LTRIM [list] [start] [stop] list 截断
  ##################################################################################
  
  127.0.0.1:6379> RPUSH mylist "hello"
  (integer) 1
  127.0.0.1:6379> RPUSH mylist "hello1"
  (integer) 2
  127.0.0.1:6379> RPUSH mylist "hello2"
  (integer) 3
  127.0.0.1:6379> RPUSH mylist "hello3"
  (integer) 4
  127.0.0.1:6379> RPUSH mylist "hello4"
  # 通过下标截取指定的长度,这个list已经被改变了, 截断了只剩下的元素!
  127.0.0.1:6379> LTRIM mylist 1 2
  OK
  127.0.0.1:6379> LRANGE mylist 0 -1
  1) "hello1"
  2) "hello2"
  
  ##################################################################################
3.8、rpoplpush
  • rpoplpush [list] [other_list]
  • 移除list的最后一个元素, 将他移动到新的list中!
  ##################################################################################
  # rpoplpush [list] [other_list] 移除list的最后一个元素, 将他移动到新的list中!
  ##################################################################################
  
  127.0.0.1:6379> RPUSH mylist "hello"
  (integer) 1
  127.0.0.1:6379> RPUSH mylist "hello1"
  (integer) 2
  127.0.0.1:6379> RPUSH mylist "hello2"
  (integer) 3
  # 移除mylist的最后一个元素, 将他移动到新的myotherlist中
  127.0.0.1:6379> rpoplpush mylist myotherlist
  "hello2"
  # 查看list的值
  127.0.0.1:6379> LRANGE mylist 0 -1
  1) "hello"
  2) "hello1"
  # 查看myotherlist的值
  127.0.0.1:6379> LRANGE myotherlist 0 -1
  1) "hello2"
  
  ##################################################################################
3.9、Lset
  • lset [key] [index] [value]
  • 将list中指定下标的值替换为另外一个值,更新操作
  ##################################################################################
  # lset [key] [index] [value] 将list中指定下标的值替换为另外一个值,更新操作
  ##################################################################################
  
  # 没有这个list这个列表或者,list没有0这个下标,所以报错
  127.0.0.1:6379> lset list 0 item
  (error) ERR no such key
  127.0.0.1:6379> lpush list value1
  (integer) 1
  127.0.0.1:6379> lrange list 0 0
  1) "value1"
  # 将list中的0下标的值替换为item,实现了更新操作
  127.0.0.1:6379> lset list 0 item
  OK
  # 查看list的0下标的值是否变化
  127.0.0.1:6379> lrange list 0 0
  1) "item"
  # 将list中的不存在下标的值替换为other, 列表list的下标不存在,故更新失败
  127.0.0.1:6379> lset list 1 other
  (error) ERR index out of range
  
  ##################################################################################
3.10、Linsert
  • LINSERT [key] ]BEFORE|AFTER] [pivot] [Value]
  • 将某个具体的Value插入到list中的某个元素的前面或者后面
  ##################################################################################
  # LINSERT [key] ]BEFORE|AFTER] [pivot] [Value] 将某个具体的Value插入到list中的某个元素的前面或者后面
  ##################################################################################
  
  127.0.0.1:6379> rpush mylist "hello"
  (integer) 1
  127.0.0.1:6379> rpush mylist "world"
  (integer) 2
  # 将other插入到mylist中的world的前面
  127.0.0.1:6379> LINSERT mylist before "world" "other"
  (integer) 3
  127.0.0.1:6379> LRANGE mylist 0 -1
  1) "hello"
  2) "other"
  3) "world"
  # 将new插入到mylist中的world的后面
  127.0.0.1:6379> LINSERT mylist after world new
  (integer) 4
  127.0.0.1:6379> LRANGE mylist 0 -1
  1) "hello"
  2) "other"
  3) "world"
  4) "new"
  
  ##################################################################################
3.11、小结
  • 实际上是一个链表, before Node after , left/right都可以插入值
  • 如果key不存在,就创建新的链表
  • 如果key存在,新增内容
  • 如果移除所有值,空链表,也代表不存在
  • 在两边插入或者改动值,效率最高,中间元素,相对来说效率会低一点
  • 消息排队!消息队列(Lpush Rpop) ,栈(Lpush, Lpop)

4、Set

  • set中的值是不能重读的!
  • 无序不重复集合
4.1、Sadd
  • SADD [key] [member …]
  • set集合中添加元素
  ##################################################################################
  # SADD [key] [member ...] set集合中添加元素
  ##################################################################################
  
  127.0.0.1:6379> SADD myset "hello"
  (integer) 1
  127.0.0.1:6379> SADD myset "SliverHorn"
  (integer) 1
  127.0.0.1:6379> SADD myset "SliverHorn7"
  (integer) 1
  
  ##################################################################################
  127.0.0.1:6379> SISMEMBER myset hello
  (integer) 1
  127.0.0.1:6379> SISMEMBER myset world
  (integer) 0
4.2、Smembers
  • SMEMBERS [key]
  • 查看指定set的所有值
  ##################################################################################
  # SMEMBERS [key] 查看指定set的所有值
  ##################################################################################
  
  127.0.0.1:6379> SMEMBERS myset
  1) "hello"
  2) "SliverHorn"
  3) "SliverHorn7"
  
  ##################################################################################
4.3、Sismember
  • SISMEMBER [key] [member]
  • 判断某一个值是不是在set集合中
  ##################################################################################
  # SISMEMBER [key] [member] 判断某一个值是不是在set集合中
  ##################################################################################
  
  127.0.0.1:6379> SISMEMBER myset hello
  (integer) 1
  127.0.0.1:6379> SISMEMBER myset world
  (integer) 0
  
  ##################################################################################
4.4、Scard
  • SCARD [key]
  • 获取set集合中的内容元素个数
  ###################################################################################
  # SCARD [key] 获取set集合中的内容元素个数
  ###################################################################################
  
  127.0.0.1:6379> SCARD myset
  (integer) 3
  
  ###################################################################################
4.5、Srem
  • SREM [key] [member …]
  • 移除一个或多个set集合中的值
  ##################################################################################
  # SREM [key]  [member ...] 移除一个或多个set集合中的值
  ##################################################################################
  
  127.0.0.1:6379> SCARD myset
  (integer) 3
  127.0.0.1:6379> SREM myset hello
  (integer) 1
  127.0.0.1:6379> SCARD myset
  (integer) 2
  127.0.0.1:6379> SMEMBERS myset
  1) "SliverHorn"
  2) "SliverHorn7"
  
  ##################################################################################
4.6、Srandmember
  • SRANDMEMBER [key] [count]
  • 随机抽取set集合中的一个或多个元素
  ##################################################################################
  # SRANDMEMBER [key] [count] 随机抽取set集合中的一个或多个元素
  ##################################################################################
  
  # 查看set集合的元素
  127.0.0.1:6379> SMEMBERS myset
  1) "SliverHorn"
  2) "SliverHorn7"
  # 随机抽选出一个元素
  
    127.0.0.1:6379> SRANDMEMBER myset
  "SliverHorn7"
  
    # 随机抽选出一个元素
  
    127.0.0.1:6379> SRANDMEMBER myset
    "SliverHorn"
  
    # 随机抽选出两个元素
  
    127.0.0.1:6379> SRANDMEMBER myset 2
    1) "SliverHorn"
    2) "SliverHorn7"
  
    ##################################################################################
4.7、Spop
  • SPOP key [count]
  • 移除set集合中一个或者多个
  ##################################################################################
  # SPOP key [count] 移除set集合中一个或者多个
  ##################################################################################
   
   # 查看set集合的元素
   127.0.0.1:6379> SMEMBERS myset
   1) "SliverHorn"
   2) "SliverHorn7"
  3) "b"
    4) "a"
  5) "c"
    # 随机移除set集合的某一个元素
    127.0.0.1:6379> spop myset
    "c"
    # 随机移除set集合的某一个元素
    127.0.0.1:6379> spop myset
    "SliverHorn"
    # 查看set集合的元素
    127.0.0.1:6379> SMEMBERS myset
    1) "SliverHorn7"
    2) "b"
    3) "a"
    
    ##################################################################################
4.8、Smove
  • SMOVE [source] [destination] [member]
  • 移动一个指定set集合中的指定成员到另外一个set集合
  ##################################################################################
  # SMOVE [source] [destination] [member] 移动一个指定set集合中的指定成员到另外一个set集合
  ##################################################################################
  
  127.0.0.1:6379> sadd myset "hello"
  (integer) 1
  127.0.0.1:6379> sadd myset "world"
  (integer) 1
  127.0.0.1:6379> sadd myset "SliverHorn"
  (integer) 1
  127.0.0.1:6379> sadd myset2 "set2"
  (integer) 1
  127.0.0.1:6379> smove myset myset2 "SliverHorn"
  (integer) 1
  127.0.0.1:6379> smembers myset
  1) "world"
  2) "hello"
  127.0.0.1:6379> smembers myset2
  1) "SliverHorn"
  2) "set2"
  
  ##################################################################################
4.9、Sdiff,Sinter,Sunion
  • 数字集合类运算

    • 差集 SDIFF
      • SDIFF [key] [key …]
    • 交集 SINTER
      • SINTER [key] [key …]
    • 并集 SUNION
      • SUNION [key] [key …]
    • 运用场景
      • 微博,A用户将所有关注的人放在一个set集合中!将它的粉丝放到一个集合中!
      • 共同关注,共同爱好, 二度好友,推荐好友(六度分割理论)
  ##################################################################################
  # 初始化测试数据
  ##################################################################################
  
  127.0.0.1:6379> sadd key1 a
  (integer) 1
  127.0.0.1:6379> sadd key1 b
  (integer) 1
  127.0.0.1:6379> sadd key1 c   
  (integer) 1
  127.0.0.1:6379> sadd key2 c
  (integer) 1
  127.0.0.1:6379> sadd key2 d
  (integer) 1
  127.0.0.1:6379> sadd key2 e
  (integer) 1
  
  ##################################################################################
  
  ##################################################################################
  #  sdiff [key] [key ...] 计算以第一个key为准,key1与key2的差集
  ##################################################################################
  
  127.0.0.1:6379> SDIFF key1 key2
  1) "a"
  2) "b"
  
  ##################################################################################
  
  ##################################################################################
  # SINTER [key] [key ...] 计算key1与key2的交集
  ##################################################################################
  
  127.0.0.1:6379> SINTER key1 key2
  1) "c"
  
  ##################################################################################
  
  ##################################################################################
  # SUNION [key] [key ...] 计算key1与key2
  ##################################################################################
  
  127.0.0.1:6379> SUNION key1 key2
  1) "c"
  2) "e"
  3) "a"
  4) "b"
  5) "d"
  
  ##################################################################################

5、Hash(哈希)

  • Map集合
  • Key-Map
  • Key-
  • 本质和String没有太大的区别, 还是一个简单的Key-value!
  • 适用于变动的数据,比如用户信息之类,或者经常变动的信息
  • hash更适合于对象的存储,String更适合字符串的存储
5.1、Hset
  • HSET [key] [field] [value]
  • set一个 key-value到hash中
  ####################################################################################
  # HSET [key] [field] [value]  Set 一个 key-value
  ####################################################################################
  
  127.0.0.1:6379> hset myhash field1 SliverHorn
  (integer) 1
  
  ####################################################################################
5.2、Hget
  • HGET [key] [field]
  • 获取hash中一个字段值
 ####################################################################################
   # HGET [key] [field] 获取hash中一个字段值
   ####################################################################################
 
 127.0.0.1:6379> hget myhash field1
   "SliverHorn"
 
 ####################################################################################
5.3、Hmset
  • HMSET [key] [field] [value] [field value …]
  • set多个key-value到hash中
  ###################################################################################
  # HMSET [key] [field] [value] [field value ...] set多个key-value到hash中
  ###################################################################################
  
  127.0.0.1:6379> HMSET myhash field1 hello field2 world
  OK
  
  ###################################################################################
5.4、Hmget
  • HMGET key field [field …]
  • 获取多个字段值
  #################################################################################### HMGET key field [field ...] 获取多个字段值
  ###################################################################################
    
  127.0.0.1:6379> HMGET myhash field1 field2
  1) "hello"
  2) "world"
    
  ###################################################################################
5.5、Hgetall
  • HGETALL [key]
  • 获取hash的全部数据
  ##################################################################################
  # HGETALL [key] 获取hash的全部数据
  ##################################################################################
  
  127.0.0.1:6379> HGETALL myhash
  3) "field1"
  4) "hello"
  5) "field2"
  6) "world"
  ##################################################################################
5.6、Hdel
  • HDEL [key] [field] [field …]
  • 删除hash中一个或多个字段!对应的字段值也会消失
  ##################################################################################
   # HDEL [key] [field] [field ...] 删除hash中一个或多个字段!对应的字段值也会消失
  ##################################################################################
  
  127.0.0.1:6379> HDEL myhash field1
  (integer) 1
  127.0.0.1:6379> HGETALL myhash
  1) "field2"
  2) "world"
    
  ##################################################################################
5.7、Hlen
  • HLEN [key]
  • 获取hash的字段数量
  ##################################################################################
  # HLEN [key] 获取hash的字段数量
  ##################################################################################
  
  127.0.0.1:6379> HLEN myhash
  (integer) 1
  127.0.0.1:6379> hset myhash field1 hello
  (integer) 1
  127.0.0.1:6379> HLEN myhash
  (integer) 2
  
  ##################################################################################
5.8、Hexists
  • HEXISTS [key] [field]
  • 判断某个hash中是否含有某个字段
  ##################################################################################
  # HEXISTS [key] [field] 判断某个hash中是否含有某个字段
  ##################################################################################
  
  127.0.0.1:6379> HEXISTS myhash field1
  (integer) 1
  127.0.0.1:6379> HEXISTS myhash field3
  (integer) 0
  
  ##################################################################################
5.9、Hkeys
  • HKEYS [key]
  • 获取所有的field
  #################################################################################### HKEYS [key] 获取所有的field
  ###################################################################################
    
  127.0.0.1:6379> HKEYS myhash
  1) "field2"
  2) "field1"
    
  ###################################################################################
5.10、Hvals
  • HVALS [key]
  • 获取所有的value
  ###################################################################################
  # HVALS [key] 获取所有的value
  ###################################################################################
  
  127.0.0.1:6379> HVALS myhash
  1) "world"
  2) "hello"
  ###################################################################################
5.11、Hincrby
  • HINCRBY [key] [field] [increment]
  • hash中某个字段增加指定值(increment为负数则为减少指定值)
  ##################################################################################
  # HINCRBY [key] [field] [increment] hash中某个字段增加指定值  ##################################################################################
    
  127.0.0.1:6379> HSET myhash field3 7
  (integer) 1
  127.0.0.1:6379> HINCRBY myhash field3 1
  (integer) 8
  127.0.0.1:6379> HINCRBY myhash field3 -1
  (integer) 7
  
  ##################################################################################
5.12、Hsetnx
  • HSETNX [key] [field] [value]
  • 如果field存在则可以设置值,如果field不存在则不能设置值
  ##################################################################################
  # HSETNX [key] [field] [value] 如果field存在则可以设置值,如果field不存在则不能设置值
  ##################################################################################
  
  127.0.0.1:6379> HSETNX myhash field4 hello
  (integer) 1
  127.0.0.1:6379> HSETNX myhash field4 hello
  (integer) 0
  
  ##################################################################################

6、Zset(有序集合)

  • 在set的基础上,增加一个值set k1 v1

  • 在zset上 zset k1 score v1

  • 案例思路:

    • set排序,存储班级成绩表, 工资表排序!
    • 普通消息:1.重要的信息,2.带权重进行判断
    • 排行版应用实现,取Top N测试!
6.1、Zadd
  • ZADD [key] [score] [member] [score member …]
  • 添加一个或多个zset的值
  ################################################################################## # ZADD [key]  [score] [member] [score member ...] 添加一个或多个zset的值
  ##################################################################################
    
  127.0.0.1:6379> ZADD myzset 1 one
  (integer) 1
  127.0.0.1:6379> ZADD myzset 2 two 3 three
  (integer) 2
  
  ##################################################################################
6.2、Zrange
  • ZRANGE [key] [start] [stop] [WITHSCORES]
  • 遍历zset的所有值
  ##################################################################################
  # ZRANGE [key] [start] [stop] [WITHSCORES] 遍历zset的所有值
  ##################################################################################
  
  127.0.0.1:6379> ZRANGE myzset 0 -1
  1) "one"
  2) "two"
  3) "three"
  
  ##################################################################################
6.3、Zrangebyscore
  • ZRANGEBYSCORE [key] [min] [max] [WITHSCORES] [LIMIT offset count]
  • 通过字段score排序
  ##################################################################################
  # ZRANGEBYSCORE [key] [min] [max] [WITHSCORES] [LIMIT offset count]
  # 通过字段score排序  ##################################################################################
    
  # 初始化三条用户数据
  127.0.0.1:6379> zadd salary 2500 xiaohong
  (integer) 1
  127.0.0.1:6379> zadd salary 5000 SliverHorn
  (integer) 1
  127.0.0.1:6379> zadd salary 200 zhangsan
  (integer) 1
    
  # 显示所有用户,根据score有小到大排序
  127.0.0.1:6379> ZRANGEBYSCORE salary -inf +inf
  1) "zhangsan"
  2) "xiaohong"
  3) "SliverHorn"
  # 显示所有用户,根据score有小到大排序,并附带score
  127.0.0.1:6379> ZRANGEBYSCORE salary -inf +inf withscores
  1) "zhangsan"
  2) "200"
  3) "xiaohong"
  4) "2500"
  5) "SliverHorn"
  6) "5000"
  # 显示score小于2500的升序排列的用户数据
  127.0.0.1:6379> ZRANGEBYSCORE salary -inf 2500  withscores
  1) "zhangsan"
  2) "200"
  3) "xiaohong"
  4) "2500"
  ##################################################################################
6.4、Zrevrange
  • ZREVRANGE key start stop [WITHSCORES]
  • 从大到小排序 遍历zset
  ###################################################################################
  # ZREVRANGE key start stop [WITHSCORES] 从大到小排序 遍历zset
  ###################################################################################
  
  127.0.0.1:6379> ZREVRANGE salary 0 -1
  1) "SliverHorn"
  2) "zhangsan"
  
  ###################################################################################
6.5、Zrem
  • ZREM key member [member …]
  • 移除zset的一个或多个元素
  ##################################################################################
  # ZREM key member [member ...] 移除zset的一个或多个元素
  ##################################################################################
  
  127.0.0.1:6379> ZRANGE salary 0 -1
  1) "zhangsan"
  2) "xiaohong"
  3) "SliverHorn"
  127.0.0.1:6379> ZREM salary xiaohong
  (integer) 1
  127.0.0.1:6379> ZRANGE salary 0 -1
  1) "zhangsan"
  2) "SliverHorn"
  
  ##################################################################################
6.6、Zcard
  • ZCARD [key]
  • 获取zset集合中的内容元素个数
  ###################################################################################
  # ZCARD [key] 获取zset集合中的内容元素个数
  ###################################################################################
  
  127.0.0.1:6379> ZCARD salary
  (integer) 2
  
  ###################################################################################
6.7、Zcount
  • ZCOUNT [key] [min] [max]
  • 获取指定区间的成员数量
  ##################################################################################
  # ZCOUNT [key] [min] [max] 获取指定区间的成员数量
  ##################################################################################
   
  127.0.0.1:6379> zadd myzset 1 hello
  (integer) 1
  127.0.0.1:6379> zadd myzset 2 world 3 SliverHorn
  (integer) 2
  127.0.0.1:6379> ZRANGE myzset 0 -1
  1) "hello"
  2) "world"
  3) "SliverHorn"
  127.0.0.1:6379> ZCOUNT myzset 1 3
  (integer) 3
  127.0.0.1:6379> ZCOUNT myzset 1 2
  (integer) 2
     #################################################################################
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值