一、什么是Redis
Redis是现在最受欢迎的NoSQL数据库之一,是一款内存高速缓存数据库。Redis全称为:Remote Dictionary Server (远程字典服务),Redis是一个使用ANSI C编写的开源、包含多种数据结构、支持网络、基于内存、可选持久性的键值对存储数据库,其具备如下特性:
- 基于内存运行,性能高效
- 支持分布式,理论上可以无限扩展
- key-value存储系统
- 开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API
相比于其他数据库类型,Redis具备的特点是:
- C/S通讯模型
- 单进程单线程模型
- 丰富的数据类型
- 操作具有原子性
- 持久化
- 高并发读写
- 支持lua脚本
二、为什么使用Redis
- 简单稳定
- Redis使用单线程模型
- Redis源码较少
- Redis依赖操作系统库少
- 运行速度快
- 基于内存运行
- C语言实现
- Redis命令是单线程执行的,避免了多线程频繁切换性能的问题(官方给的结果是读写性能达到每秒10万次以上,具体取决于机器的性能)
- 具有丰富的功能
- 提供了常用的String、List、Set、Hash、Zset 5种数据类型外,还提供了Stream、Geospatial、HyperLogLog、BitBitmap等数据类型
- 提供了键过期的功能,可以用来实现缓存
- 提供了发布和订阅功能,可以用作消息系统
- 提供简单的事务功能,在一定程度上能保证事务
- 支持Lua脚本扩展能力,可以结合Lua脚本实现新的命令
- 提供了管道能力,能将多条命令一次性传到Redis执行,减少网络开销
- 具备高可扩展、高性能和高可用特性
- 提供了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
#################################################################################