基于内存的分布式NoSQL数据库Redis(三)常用命令

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,倚天版 1GB 1个月
简介: 基于内存的分布式NoSQL数据库Redis(三)常用命令

知识点07:String类型的常用命令

  • 目标:掌握String类型的常用命令
  • 实施
  • set:给String类型的Value的进行赋值或者更新
  • 语法:set K V
  • get:读取String类型的Value的值
  • 语法:get K
  • mset:用于批量写多个String类型的KV
  • 语法:mset K1 V1 K2 V2 ……
  • mget:用于批量读取String类型的Value
  • 语法:mget K1 K2 K3 ……
  • setnx:只能用于新增数据,当K不存在时可以进行新增
  • 语法:setnx K V
  • 应用:构建抢占锁,搭配expire来使用
  • incr:用于对数值类型的字符串进行递增,递增1,一般用于做计数器
  • 语法:incr K
  • incrby:指定对数值类型的字符串增长固定的步长
  • 语法:incrby K N
  • decr:对数值类型的数据进行递减,递减1
  • 语法:decr K
  • decrby:按照指定步长进行递减
  • 语法:decrby K N
  • incrbyfloat:基于浮点数递增
  • 语法:incrbyfloat K N
  • strlen:统计字符串的长度
  • 语法:strlen K
  • getrange:用于截取字符串
  • 语法:getrange s2 start end
node1:6379> keys *
(empty list or set)
node1:6379> set s1 hadoop
OK
node1:6379> get s1
"hadoop"
node1:6379> mset s2 hive s3 spark
OK
node1:6379> keys *
1) "s3"
2) "s1"
3) "s2"
node1:6379> mget s1 s3
1) "hadoop"
2) "spark"
node1:6379> set s1 oozie
OK
node1:6379> get s1
"oozie"
node1:6379> 
node1:6379> setnx s4 hue
(integer) 1
node1:6379> get s4
"hue"
node1:6379> setnx s4 flume
(integer) 0
node1:6379> get s4
"hue"
node1:6379> set s5 2
OK
node1:6379> get s5
"2"
node1:6379> incr s5
(integer) 3
node1:6379> get s5
"3"
node1:6379> incr s5
(integer) 4
node1:6379> get s5
"4"
node1:6379> incrby s5 3
(integer) 7
node1:6379> get s5
"7"
node1:6379> decr s5
(integer) 6
node1:6379> get s5
"6"
node1:6379> decrby s5 2
(integer) 4
node1:6379> get s5
"4"
node1:6379> set s6 19.2
OK
node1:6379> get s6
"19.2"
node1:6379> incrbyfloat s6 2.5
"21.7"
node1:6379> get s6
"21.7"
node1:6379> get s1
"oozie"
node1:6379> strlen s1
(integer) 5
node1:6379> getrange s1 0 2
"ooz"
node1:6379> getrange s1 2 2
"z"
node1:6379> 
  • 小结
  • 掌握String类型的常用命令

知识点08:Hash类型的常用命令

  • 目标:掌握Hash类型的常用命令
  • 实施
  • hset:用于为某个K添加一个属性
  • 语法:hset K k v
  • hget:用于获取某个K的某个属性的值
  • 语法:hget K k
  • hmset:批量的为某个K赋予新的属性
  • 语法:hmset K k1 v1 k2 v2 ……
  • hmget:批量的获取某个K的多个属性的值
  • 语法:hmget K k1 k2 k3……
  • hgetall:获取所有属性的值
  • 语法:hgetall K
  • hdel:删除某个属性
  • 语法:hdel K k1 k2 ……
  • hlen:统计K对应的Value总的属性的个数
  • 语法:hlen K
  • hexists:判断这个K的V中是否包含这个属性
  • 语法:hexists K k
  • hvals:获取所有属性的value的
  • 语法:hvals K
node1:6379> hget m1 name
"zhangsan"
node1:6379> hget m1 age
"19"
node1:6379> hmset m1 gender male phone 110 addr shanghai
OK
node1:6379> hmget m1 name phone gender
1) "zhangsan"
2) "110"
3) "male"
node1:6379> hgetall m1
 1) "name"
 2) "zhangsan"
 3) "age"
 4) "19"
 5) "gender"
 6) "male"
 7) "phone"
 8) "110"
 9) "addr"
10) "shanghai"
node1:6379> hdel m1 gender
(integer) 1
node1:6379> hgetall m1
1) "name"
2) "zhangsan"
3) "age"
4) "19"
5) "phone"
6) "110"
7) "addr"
8) "shanghai"
node1:6379> hlen m1
(integer) 4
node1:6379> hexists m1 name
(integer) 1
node1:6379> hexists m1 gender
(integer) 0
node1:6379> hgetall m1
1) "name"
2) "zhangsan"
3) "age"
4) "19"
5) "phone"
6) "110"
7) "addr"
8) "shanghai"
node1:6379> hvals m1
1) "zhangsan"
2) "19"
3) "110"
4) "shanghai"
  • 小结
  • 掌握Hash类型的常用命令

知识点09:List类型的常用命令

  • 目标:掌握List类型的常用命令
  • 实施
  • lpush:将每个元素放到集合的左边,左序放入
  • 语法:lpush K e1 e2 e3……
  • rpush:将每个元素放到集合的右边,右序放入
  • 语法:rpush K e1 e2 e3……
  • lrange:通过下标的范围来获取元素的数据
  • 语法:lrange K start end
  • 注意:从左往右的下标从0开始,从右往左的下标从-1开始,一定是从小的到大的下标
  • lrange K 0 -1:所有元素
  • **llen:**统计集合的长度
  • 语法:llen K
  • lpop:删除左边的一个元素
  • 语法:lpop K
  • rpop:删除右边的一个元素
  • 语法:rpop K
node1:6379> lpush list1 1 2 2 3
(integer) 4
node1:6379> rpush list1 4 5 6 6 7 8
(integer) 10
node1:6379> lrange list1 0 9
 1) "3"
 2) "2"
 3) "2"
 4) "1"
 5) "4"
 6) "5"
 7) "6"
 8) "6"
 9) "7"
10) "8"
node1:6379> lrange list1 4 9
1) "4"
2) "5"
3) "6"
4) "6"
5) "7"
6) "8"
node1:6379> llen list1
(integer) 10
node1:6379> lrange list1 0 -1
 1) "3"
 2) "2"
 3) "2"
 4) "1"
 5) "4"
 6) "5"
 7) "6"
 8) "6"
 9) "7"
10) "8"
node1:6379> lrange list1 0 -3
1) "3"
2) "2"
3) "2"
4) "1"
5) "4"
6) "5"
7) "6"
8) "6"
node1:6379> lrange list1 -3 -1
1) "6"
2) "7"
3) "8"
node1:6379> lpop list1
"3"
node1:6379> rpop list1
"8"
node1:6379> lrange list1 0 -1
1) "2"
2) "2"
3) "1"
4) "4"
5) "5"
6) "6"
7) "6"
8) "7"
node1:6379> 
  • 小结
  • 掌握List类型的常用命令

知识点10:Set类型的常用命令

  • 目标:掌握Set类型的常用命令
  • 实施
  • 语法:sadd K e1 e2 e3 e4 e5……
  • smembers:用于查看Set集合的所有成员
  • 语法:smembers K
  • 语法:sismember K e1
  • srem:删除其中某个元素
  • 语法:srem K e
  • scard:统计集合长度
  • 语法:scard K
  • sunion:取两个集合的并集
  • 语法:sunion K1 K2
  • sinter:取两个集合的交集
  • 语法:sinter K1 K2
node1:6379> sadd set1 1 1 2 2 3 4 3 4
    (integer) 4
    node1:6379> smembers set1
    1) "1"
    2) "2"
    3) "3"
    4) "4"
    node1:6379> scard set1
    (integer) 4
    node1:6379> sismember set1 1
    (integer) 1
    node1:6379> sismember set1 5
    (integer) 0
    node1:6379> srem set1 3
    (integer) 1
    node1:6379> smembers set1
    1) "1"
    2) "2"
    3) "4"
    node1:6379> sadd set2 1 3 6 9 8 9
    (integer) 5
    node1:6379> sunion set1 set2
    1) "1"
    2) "2"
    3) "3"
    4) "4"
    5) "6"
    6) "8"
    7) "9"
    node1:6379> sinter set1 set2
    1) "1"
    node1:6379> 
  • 小结
  • 掌握Set类型的常用命令

知识点11:Zset类型的常用命令

  • 目标:掌握Zset类型的常用命令
  • 实施
  • zadd:用于添加元素到Zset集合中
  • 语法:zadd K score1 k1 score2 k2 ……
  • zrange:范围查询
  • 语法:zrange K start end [withscores]
  • zrevrange:倒序查询
  • 语法:zrevrange K start end [withscores]
  • zrem:移除一个元素
  • 语法:zrem K k1
  • zcard:统计集合长度
  • 语法:zcard K
  • zscore:获取评分
  • 语法:zscore K k
node1:6379> zadd zset1 99.5 yingyu 30.7 shuxue 29.9 yuwen 100 shengwu 56.73 dili
(integer) 5
node1:6379> zrange zset1 0 -1
1) "yuwen"
2) "shuxue"
3) "dili"
4) "yingyu"
5) "shengwu"
node1:6379> zrevrange zset1 0 -1
1) "shengwu"
2) "yingyu"
3) "dili"
4) "shuxue"
5) "yuwen"
node1:6379> zrevrange zset1 0 -1 withscores
 1) "shengwu"
 2) "100"
 3) "yingyu"
 4) "99.5"
 5) "dili"
 6) "56.729999999999997"
 7) "shuxue"
 8) "30.699999999999999"
 9) "yuwen"
10) "29.899999999999999"
node1:6379> 
node1:6379> zrem zset1 yuwen
(integer) 1
node1:6379> zrevrange zset1 0 -1 withscores
1) "shengwu"
2) "100"
3) "yingyu"
4) "99.5"
5) "dili"
6) "56.729999999999997"
7) "shuxue"
8) "30.699999999999999"
node1:6379> 
node1:6379> zcard zset1
(integer) 4
node1:6379> zscore zset1 shuxue
"30.699999999999999"
  • 注意:Redis中不建议存储小数值,存在精度问题,建议转换为整形存储
  • 小结
  • 掌握Zset类型的常用命令

知识点12:BitMap类型的常用命令

  • 目标:掌握BitMap类型的常用命令
  • 实施
  • 功能:通过一个String对象的存储空间,来构建位图,用每一位0和1来表示状态
  • Redis中一个String最大支持512M = 2^32次方,1字节 = 8位
  • 使用时,可以指定每一位对应的值,要么为0,要么为1,默认全部为0
  • 用下标来标记每一位,第一个位的下标为0

  • 举例:统计UV
  • 一个位图中包含很多位,可以用每一个位表示一个用户id
  • 读取数据,发现一个用户id,就将这个用户id对应的那一位改为1
  • 统计整个位图中所有1的个数,就得到了UV
  • setbit:修改某一位的值
  • 语法:setbit bit1 位置 0/1
setbit bit1 0 1
  • getbit:查看某一位的值
  • 语法:getbit K 位置
getbit bit1 9
  • bitcount:用于统计位图中所有1的个数
  • 语法:bitcount K [start end]
bitcount bit1
#start和end表示的是字节:1 字节 = 8 位
bitcount bit1 0 10
  • bitop:用于位图的运算:and/or/not/xor
  • 语法:bitop and/or/xor/not bitrs bit1 bit2
bitop and bit3 bit1 bit2
bitop or bit4 bit1 bit2
  • 小结
  • 掌握BitMap类型的常用命令

知识点13:HyperLogLog类型的常用命令

  • 目标:掌握HyperLogLog类型的常用命令
  • 实施
  • 功能:类似于Set集合,用于实现数据的去重
  • 区别:底层实现原理不一样
  • 应用:适合于数据量比较庞大的情况下的使用,存在一定的误差率
  • pfadd:用于添加元素
  • 语法:pfadd K e1 e2 e3……
pfadd pf1 userid1 userid1 userid2 userid3 userid4 userid3 userid4
pfadd pf2 userid1 userid2 userid2 userid5 userid6

         
  • pfcount:用于统计个数
  • 语法:pfcount K
pfcount pf1
  • pfmerge:用于实现集合合并
  • 语法:pfmerge pfrs pf1 pf2……
pfmerge pf3 pf1 pf2
  • 小结
  • 掌握HyperLogLog类型的常用命令
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
1天前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
这篇文章介绍了如何在SpringBoot项目中整合Redis,并探讨了缓存穿透、缓存雪崩和缓存击穿的问题以及解决方法。文章还提供了解决缓存击穿问题的加锁示例代码,包括存在问题和问题解决后的版本,并指出了本地锁在分布式情况下的局限性,引出了分布式锁的概念。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
|
1天前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
这篇文章是关于如何在SpringBoot应用中整合Redis并处理分布式场景下的缓存问题,包括缓存穿透、缓存雪崩和缓存击穿。文章详细讨论了在分布式情况下如何添加分布式锁来解决缓存击穿问题,提供了加锁和解锁的实现过程,并展示了使用JMeter进行压力测试来验证锁机制有效性的方法。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
|
1天前
|
NoSQL 安全 Java
nicelock--一个注解即可使用Redis分布式锁!
Nicelock的引入为分布式系统中的资源同步访问提供了一个简单高效和可靠的解决方案。通过注解的方式,简化了锁的实现和使用,使开发人员可以将更多精力专注于业务逻辑的实现,而不是锁的管理。此外,Nicelock在保持简单易用的同时,也提供了足够的灵活性和可靠性,满足了不同应用场景下对分布式锁的需求。
7 1
|
18天前
|
缓存 NoSQL 关系型数据库
(八)漫谈分布式之缓存篇:唠唠老生常谈的MySQL与Redis数据一致性问题!
本文来聊一个跟实际工作挂钩的老生常谈的问题:分布式系统中的缓存一致性。
73 10
|
13天前
|
存储 SQL 运维
“震撼发布!PolarDB-X:云原生分布式数据库巨擘,超高并发、海量存储、复杂查询,一网打尽!错过等哭!”
【8月更文挑战第7天】PolarDB-X 是面向超高并发、海量存储和复杂查询场景设计的云原生分布式数据库系统
67 1
|
20天前
|
Cloud Native 关系型数据库 分布式数据库
中国金融分布式数据库,双料冠军!
中国金融分布式数据库同比增长12.1%,阿里云绝对优势夺得公有云市场冠军
|
20天前
|
NoSQL 算法 Java
(十三)全面理解并发编程之分布式架构下Redis、ZK分布式锁的前世今生
本文探讨了从单体架构下的锁机制到分布式架构下的线程安全问题,并详细分析了分布式锁的实现原理和过程。
|
17天前
|
存储 负载均衡 中间件
构建可扩展的分布式数据库:技术策略与实践
【8月更文挑战第3天】构建可扩展的分布式数据库是一个复杂而具有挑战性的任务。通过采用数据分片、复制与一致性模型、分布式事务管理和负载均衡与自动扩展等关键技术策略,并合理设计节点、架构模式和网络拓扑等关键组件,可以构建出高可用性、高性能和可扩展的分布式数据库系统。然而,在实际应用中还需要注意解决数据一致性、故障恢复与容错性以及分布式事务的复杂性等挑战。随着技术的不断发展和创新,相信分布式数据库系统将在未来发挥更加重要的作用。
|
18天前
|
Cloud Native 关系型数据库 分布式数据库
中国金融分布式数据库,阿里云双料冠军!
中国金融分布式数据库,阿里云双料冠军!
36 1
|
20天前
|
存储 关系型数据库 MySQL
深度评测:PolarDB-X 开源分布式数据库的优势与实践
本文对阿里云开源分布式数据库 PolarDB-X 进行了详细评测。PolarDB-X 以其高性能、强可用性和出色的扩展能力在云原生数据库市场中脱颖而出。文章首先介绍了 PolarDB-X 的核心产品优势,包括金融级高可靠性、海量数据处理能力和高效的混合负载处理能力。随后,分析了其分布式架构设计,包括计算节点、存储节点、元数据服务和日志节点的功能分工。评测还涵盖了在 Windows 平台通过 WSL 环境部署 PolarDB-X 的过程,强调了环境准备和工具安装的关键步骤。使用体验方面,PolarDB-X 在处理分布式事务和实时分析时表现稳定,但在网络问题和性能瓶颈上仍需优化。最后,提出了改进建
6592 2